@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,156 +0,0 @@
1
- /**
2
- * TradingBridge — host-side trading callback contract for Unmanaged mode.
3
- *
4
- * When a chart user performs a trading action (drag-to-place, cancel, bracket
5
- * adjust, etc.) the chart emits a typed Intent and defers all confirmation to
6
- * the host. The chart NEVER self-confirms order state. The host must push
7
- * the resulting confirmed ChartOrder back via TradingOverlayStore.
8
- *
9
- * Usage (consumer / host app):
10
- *
11
- * ```tsx
12
- * import type { TradingBridgeCallbacks } from '@forgecharts/sdk/react';
13
- *
14
- * const bridge: TradingBridgeCallbacks = {
15
- * onPlaceOrderIntent: (intent) => myBroker.placeOrder(intent),
16
- * onModifyOrderIntent: (intent) => myBroker.modifyOrder(intent),
17
- * onCancelOrderIntent: (intent) => myBroker.cancelOrder(intent),
18
- * onBracketAdjustIntent: (intent) => myBroker.adjustBracket(intent),
19
- * };
20
- *
21
- * <ChartCanvas
22
- * symbol="BTCUSDT"
23
- * timeframe="1h"
24
- * tradingBridge={bridge}
25
- * />
26
- * ```
27
- *
28
- * Debug logging:
29
- * Wrap your callbacks with `createTradingBridgeLogger` to get structured
30
- * console output in development:
31
- *
32
- * ```ts
33
- * tradingBridge={createTradingBridgeLogger(bridge, 'MyChart')}
34
- * ```
35
- */
36
-
37
- import type {
38
- PlaceOrderIntent,
39
- ModifyOrderIntent,
40
- CancelOrderIntent,
41
- BracketAdjustIntent,
42
- } from '@forgecharts/types';
43
-
44
- // ─── Public callback contract ─────────────────────────────────────────────────
45
-
46
- /**
47
- * Injectable callback bag for the chart-to-host trading bridge.
48
- *
49
- * All callbacks are optional — omit any you do not handle. The chart will
50
- * still emit the intent but silently discard it if the corresponding callback
51
- * is not provided.
52
- *
53
- * The return types are `void | Promise<void>` so hosts can fire-and-forget or
54
- * await before side-effects. The chart does not await the returned promise —
55
- * confirmation always flows back through `TradingOverlayStore`.
56
- */
57
- export interface TradingBridgeCallbacks {
58
- /**
59
- * Called when the user triggers a new order placement.
60
- * The host should validate, forward to the broker, and then call
61
- * `overlayStore.upsertOrder(confirmedOrder)` once acknowledged.
62
- */
63
- onPlaceOrderIntent?: (intent: PlaceOrderIntent) => void | Promise<void>;
64
-
65
- /**
66
- * Called when the user drags an order line to a new price or edits it via UI.
67
- * The host should send the modification to the broker and update the overlay
68
- * store with the modified order.
69
- */
70
- onModifyOrderIntent?: (intent: ModifyOrderIntent) => void | Promise<void>;
71
-
72
- /**
73
- * Called when the user clicks the cancel control on an order line.
74
- * The host should cancel at the venue and call `overlayStore.removeOrder(id)`.
75
- */
76
- onCancelOrderIntent?: (intent: CancelOrderIntent) => void | Promise<void>;
77
-
78
- /**
79
- * Called when the user drags a bracket leg (stop-loss or take-profit).
80
- * The host adjusts both legs atomically and updates the overlay store.
81
- */
82
- onBracketAdjustIntent?: (intent: BracketAdjustIntent) => void | Promise<void>;
83
- }
84
-
85
- // ─── Debug logger ─────────────────────────────────────────────────────────────
86
-
87
- /**
88
- * Wraps a `TradingBridgeCallbacks` object and logs all emitted intents to the
89
- * console. Only active when `process.env.NODE_ENV !== 'production'`.
90
- *
91
- * @param callbacks The real callbacks to delegate to after logging.
92
- * @param label Optional label prepended to log messages (e.g. chart id or symbol).
93
- * @returns A new `TradingBridgeCallbacks` that logs then delegates.
94
- *
95
- * @example
96
- * ```ts
97
- * tradingBridge={createTradingBridgeLogger(bridge, 'BTCUSDT')}
98
- * ```
99
- */
100
- export function createTradingBridgeLogger(
101
- callbacks: TradingBridgeCallbacks,
102
- label?: string,
103
- ): TradingBridgeCallbacks {
104
- if (process.env.NODE_ENV === 'production') return callbacks;
105
-
106
- const tag = label ? `[TradingBridge:${label}]` : '[TradingBridge]';
107
-
108
- return {
109
- onPlaceOrderIntent: (intent) => {
110
- console.debug(
111
- `${tag} PLACE side=%s type=%s qty=%s price=%s stopPrice=%s correlationId=%s`,
112
- intent.side,
113
- intent.orderType,
114
- intent.qty,
115
- intent.limitPrice ?? '—',
116
- intent.stopPrice ?? '—',
117
- intent.correlationId,
118
- intent,
119
- );
120
- return callbacks.onPlaceOrderIntent?.(intent);
121
- },
122
-
123
- onModifyOrderIntent: (intent) => {
124
- console.debug(
125
- `${tag} MODIFY orderId=%s limitPrice=%s stopPrice=%s qty=%s`,
126
- intent.orderId,
127
- intent.limitPrice ?? '—',
128
- intent.stopPrice ?? '—',
129
- intent.qty ?? '—',
130
- intent,
131
- );
132
- return callbacks.onModifyOrderIntent?.(intent);
133
- },
134
-
135
- onCancelOrderIntent: (intent) => {
136
- console.debug(
137
- `${tag} CANCEL orderId=%s symbol=%s`,
138
- intent.orderId,
139
- intent.symbol,
140
- intent,
141
- );
142
- return callbacks.onCancelOrderIntent?.(intent);
143
- },
144
-
145
- onBracketAdjustIntent: (intent) => {
146
- console.debug(
147
- `${tag} BRACKET_ADJUST entry=%s sl=%s tp=%s`,
148
- intent.entryOrderId,
149
- intent.stopLossPrice ?? '—',
150
- intent.takeProfitPrice ?? '—',
151
- intent,
152
- );
153
- return callbacks.onBracketAdjustIntent?.(intent);
154
- },
155
- };
156
- }
@@ -1,228 +0,0 @@
1
- /**
2
- * ChartWorkspace — structural layout assembly.
3
- *
4
- * Renders: TabBar + TopToolbar + (ChartCanvas slots + RightToolbar) + BottomToolbar.
5
- *
6
- * This component is intentionally stateless — all state lives in the parent
7
- * (ManagedAppShell). It provides the visual skeleton and prop routing only.
8
- */
9
-
10
- import React from 'react';
11
- import { TabBar } from './TabBar';
12
- import type { TabItem } from './TabBar';
13
- import { TopToolbar } from './toolbars/TopToolbar';
14
- import { RightToolbar } from './toolbars/RightToolbar';
15
- import { BottomToolbar } from './toolbars/BottomToolbar';
16
- import type { TradingSession } from './toolbars/BottomToolbar';
17
- import type { LayoutRecord } from './LayoutMenu';
18
- import type { ChartTheme, IndicatorConfig, ISymbolResolver } from '@forgecharts/types';
19
-
20
- export type { TradingSession };
21
-
22
- export type ChartWorkspaceProps = {
23
- // ── TabBar ─────────────────────────────────────────────────────────────────
24
- tabs: Array<{ id: string; label: string; isSaved?: boolean }>;
25
- activeTabId: string;
26
- onSelectTab: (id: string) => void;
27
- onAddTab: () => void;
28
- onCloseTab: (id: string) => void;
29
- onRenameTab: (id: string, label: string) => void;
30
- // ── TopToolbar ─────────────────────────────────────────────────────────────
31
- symbol: string;
32
- timeframe: string;
33
- theme: ChartTheme;
34
- customTimeframes: string[];
35
- favoriteTfs: string[];
36
- onSymbolChange: (s: string) => void;
37
- onTimeframeChange: (tf: string) => void;
38
- onAddCustomTimeframe: (tf: string) => void;
39
- onFavoriteTfsChange: (favs: string[]) => void;
40
- onAddIndicator: (config: IndicatorConfig) => void;
41
- onToggleTheme: () => void;
42
- onCopyScreenshot: () => void;
43
- onDownloadScreenshot: () => void;
44
- onFullscreen: () => void;
45
- isFullscreen: boolean;
46
- currentLayoutName?: string;
47
- currentLayoutId?: string;
48
- autoSave: boolean;
49
- onFetchLayouts: () => Promise<LayoutRecord[]>;
50
- onSaveLayout: (name: string) => Promise<void>;
51
- onLoadLayout: (id: string) => Promise<void>;
52
- onRenameLayout: (name: string) => Promise<void>;
53
- onCopyLayout: (name: string) => Promise<void>;
54
- onToggleAutoSave: (enabled: boolean) => void;
55
- /** Resolver used by the symbol search dialog. */
56
- symbolResolver: ISymbolResolver;
57
- onDeleteLayout: (id: string) => Promise<void>;
58
- onOpenLayoutInNewTab: (id: string) => Promise<void>;
59
- // ── RightToolbar ────────────────────────────────────────────────────────────
60
-
61
- watchlistOpen: boolean;
62
- onToggleWatchlist: () => void;
63
- // ── BottomToolbar ───────────────────────────────────────────────────────────
64
- activeSymbol: string;
65
- timezone: string;
66
- onTimezoneChange: (tz: string) => void;
67
- session: TradingSession;
68
- onSessionChange: (s: TradingSession) => void;
69
- scriptDrawerOpen: boolean;
70
- onToggleScriptDrawer: () => void;
71
- // ── Trade button (TopToolbar) ────────────────────────────────────────────────
72
- showTradeButton?: boolean;
73
- tradeDrawerOpen?: boolean;
74
- onToggleTradeDrawer?: () => void;
75
- // ── Chart slot (parent renders all tab charts) ───────────────────────────────
76
- chartSlots: React.ReactNode;
77
- // ── Unlicensed overlay ───────────────────────────────────────────────────────
78
- isLicensed: boolean;
79
- // ── Loading overlay ──────────────────────────────────────────────────────────
80
- wsLoaded: boolean;
81
- // ── Drawers (passed through as assembled React nodes) ────────────────────────
82
- drawers?: React.ReactNode;
83
- };
84
-
85
- // ─── Re-export TabItem for consumers ─────────────────────────────────────────
86
- export type { TabItem };
87
-
88
- export function ChartWorkspace({
89
- // TabBar
90
- tabs, activeTabId, onSelectTab, onAddTab, onCloseTab, onRenameTab,
91
- // TopToolbar
92
- symbol, timeframe, theme, customTimeframes, favoriteTfs,
93
- onSymbolChange, onTimeframeChange, onAddCustomTimeframe, onFavoriteTfsChange,
94
- onAddIndicator, onToggleTheme, onCopyScreenshot, onDownloadScreenshot,
95
- onFullscreen, isFullscreen, currentLayoutName, currentLayoutId, autoSave,
96
- onFetchLayouts, onSaveLayout, onLoadLayout, onRenameLayout, onCopyLayout,
97
- onToggleAutoSave, onDeleteLayout, onOpenLayoutInNewTab,
98
- showTradeButton, tradeDrawerOpen, onToggleTradeDrawer, symbolResolver,
99
- // RightToolbar
100
- watchlistOpen, onToggleWatchlist,
101
- // BottomToolbar
102
- activeSymbol, timezone, onTimezoneChange, session, onSessionChange,
103
- scriptDrawerOpen, onToggleScriptDrawer,
104
- // Chart + state
105
- chartSlots, isLicensed, wsLoaded, drawers,
106
- }: ChartWorkspaceProps) {
107
- const tabItems: TabItem[] = tabs.map((t) => ({
108
- id: t.id,
109
- label: t.label,
110
- ...(t.isSaved !== undefined ? { isSaved: t.isSaved } : {}),
111
- }));
112
-
113
- return (
114
- <div
115
- style={{
116
- display: 'flex',
117
- flexDirection: 'column',
118
- height: '100%',
119
- background: 'var(--shelf-bg)',
120
- padding: 6,
121
- gap: 4,
122
- }}
123
- >
124
- {/* ── Loading overlay ──────────────────────────────────────────────── */}
125
- {!wsLoaded && (
126
- <div style={{
127
- position: 'absolute', inset: 0, display: 'flex',
128
- alignItems: 'center', justifyContent: 'center',
129
- background: 'var(--bg)', zIndex: 1000,
130
- }}>
131
- <svg width="32" height="32" viewBox="0 0 32 32" style={{ animation: 'spin 0.9s linear infinite' }}>
132
- <circle cx="16" cy="16" r="12" fill="none" stroke="var(--border)" strokeWidth="3" />
133
- <path d="M16 4 A12 12 0 0 1 28 16" fill="none" stroke="var(--primary)" strokeWidth="3" strokeLinecap="round" />
134
- </svg>
135
- <style>{`@keyframes spin { to { transform: rotate(360deg); } }`}</style>
136
- </div>
137
- )}
138
-
139
- <TabBar
140
- tabs={tabItems}
141
- activeId={activeTabId}
142
- onSelect={onSelectTab}
143
- onAdd={onAddTab}
144
- onClose={onCloseTab}
145
- onRename={onRenameTab}
146
- />
147
-
148
- {/* ── Top toolbar ──────────────────────────────────────────────────── */}
149
- <TopToolbar
150
- symbol={symbol}
151
- timeframe={timeframe}
152
- theme={theme}
153
- customTimeframes={customTimeframes}
154
- favorites={favoriteTfs}
155
- onSymbolChange={onSymbolChange}
156
- onTimeframeChange={onTimeframeChange}
157
- onAddCustomTimeframe={onAddCustomTimeframe}
158
- onFavoritesChange={onFavoriteTfsChange}
159
- onAddIndicator={onAddIndicator}
160
- onToggleTheme={onToggleTheme}
161
- onCopyScreenshot={onCopyScreenshot}
162
- onDownloadScreenshot={onDownloadScreenshot}
163
- onFullscreen={onFullscreen}
164
- isFullscreen={isFullscreen}
165
- currentLayoutName={currentLayoutName}
166
- currentLayoutId={currentLayoutId}
167
- autoSave={autoSave}
168
- onFetchLayouts={onFetchLayouts}
169
- onSaveLayout={onSaveLayout}
170
- onLoadLayout={onLoadLayout}
171
- onRenameLayout={onRenameLayout}
172
- onCopyLayout={onCopyLayout}
173
- onToggleAutoSave={onToggleAutoSave}
174
- onDeleteLayout={onDeleteLayout}
175
- onOpenLayoutInNewTab={onOpenLayoutInNewTab}
176
- symbolResolver={symbolResolver}
177
- {...(showTradeButton !== undefined ? { showTradeButton } : {})}
178
- {...(tradeDrawerOpen !== undefined ? { tradeDrawerOpen } : {})}
179
- {...(onToggleTradeDrawer !== undefined ? { onToggleTradeDrawer } : {})}
180
- />
181
-
182
- {/* ── Chart area ───────────────────────────────────────────────────── */}
183
- <div style={{ flex: 1, display: 'flex', gap: 8, minHeight: 0, overflow: 'hidden' }}>
184
- <div style={{ position: 'relative', flex: 1, display: 'flex', gap: 8, minWidth: 0, minHeight: 0 }}>
185
- {/* Unlicensed overlay */}
186
- {!isLicensed && (
187
- <div style={{
188
- position: 'absolute', inset: 0, zIndex: 100,
189
- background: 'rgba(0,0,0,0.6)',
190
- backdropFilter: 'blur(4px)',
191
- display: 'flex', flexDirection: 'column',
192
- alignItems: 'center', justifyContent: 'center',
193
- gap: 12,
194
- }}>
195
- <svg viewBox="0 0 24 24" width="40" height="40" fill="none" stroke="rgba(255,255,255,0.7)" strokeWidth="1.8" strokeLinecap="round" strokeLinejoin="round">
196
- <rect x="3" y="11" width="18" height="11" rx="2" />
197
- <path d="M7 11V7a5 5 0 0110 0v4" />
198
- </svg>
199
- <div style={{ color: '#fff', fontWeight: 700, fontSize: 18, letterSpacing: '0.01em' }}>Unlicensed</div>
200
- <div style={{ color: 'rgba(255,255,255,0.65)', fontSize: 13 }}>Please activate your license in the admin studio</div>
201
- </div>
202
- )}
203
- {/* Chart instance slots */}
204
- <div style={{ position: 'relative', flex: 1, minWidth: 0, minHeight: 0 }}>
205
- {chartSlots}
206
- </div>
207
- <RightToolbar
208
- watchlistOpen={watchlistOpen}
209
- onToggleWatchlist={onToggleWatchlist}
210
- />
211
- </div>
212
- {/* Drawer panels passed from parent (ScriptDrawer, WatchlistDrawer) */}
213
- {drawers}
214
- </div>
215
-
216
- {/* ── Bottom bar ───────────────────────────────────────────────────── */}
217
- <BottomToolbar
218
- symbol={activeSymbol}
219
- timezone={timezone}
220
- onTimezoneChange={onTimezoneChange}
221
- session={session}
222
- onSessionChange={onSessionChange}
223
- onToggleScriptDrawer={onToggleScriptDrawer}
224
- scriptDrawerOpen={scriptDrawerOpen}
225
- />
226
- </div>
227
- );
228
- }
@@ -1,131 +0,0 @@
1
- /**
2
- * FloatingPanel — a draggable, resizable floating panel shell.
3
- *
4
- * Renders `position: fixed` with a title bar (drag to move) and 8 resize
5
- * handles (edges + corners). Pass panel content as `children`.
6
- */
7
-
8
- import { useRef, useState } from 'react';
9
-
10
- type Pos = { x: number; y: number };
11
- type Size = { w: number; h: number };
12
-
13
- type Props = {
14
- title: React.ReactNode;
15
- onClose: () => void;
16
- defaultWidth?: number;
17
- defaultHeight?: number;
18
- minWidth?: number;
19
- minHeight?: number;
20
- children: React.ReactNode;
21
- };
22
-
23
- export function FloatingPanel({
24
- title,
25
- onClose,
26
- defaultWidth = 380,
27
- defaultHeight = 520,
28
- minWidth = 200,
29
- minHeight = 120,
30
- children,
31
- }: Props) {
32
- const [pos, setPos] = useState<Pos>(() => ({
33
- x: Math.max(0, window.innerWidth - defaultWidth - 24),
34
- y: 72,
35
- }));
36
- const [size, setSize] = useState<Size>({ w: defaultWidth, h: defaultHeight });
37
-
38
- // Refs capture drag-start values to avoid stale-closure accumulation
39
- const moveRef = useRef<{ ox: number; oy: number; px: number; py: number } | null>(null);
40
- const resizeRef = useRef<{
41
- edges: string;
42
- ox: number; oy: number;
43
- pw: number; ph: number;
44
- px: number; py: number;
45
- } | null>(null);
46
-
47
- // ── Drag to move ──────────────────────────────────────────────────────────
48
- const startMove = (e: React.MouseEvent) => {
49
- if ((e.target as HTMLElement).closest('.fp-close')) return;
50
- e.preventDefault();
51
- moveRef.current = { ox: e.clientX, oy: e.clientY, px: pos.x, py: pos.y };
52
- const onMove = (ev: MouseEvent) => {
53
- if (!moveRef.current) return;
54
- setPos({
55
- x: moveRef.current.px + ev.clientX - moveRef.current.ox,
56
- y: moveRef.current.py + ev.clientY - moveRef.current.oy,
57
- });
58
- };
59
- const onUp = () => {
60
- moveRef.current = null;
61
- window.removeEventListener('mousemove', onMove);
62
- window.removeEventListener('mouseup', onUp);
63
- };
64
- window.addEventListener('mousemove', onMove);
65
- window.addEventListener('mouseup', onUp);
66
- };
67
-
68
- // ── Resize from any edge/corner ───────────────────────────────────────────
69
- const startResize = (e: React.MouseEvent, edges: string) => {
70
- e.preventDefault();
71
- e.stopPropagation();
72
- resizeRef.current = {
73
- edges,
74
- ox: e.clientX, oy: e.clientY,
75
- pw: size.w, ph: size.h,
76
- px: pos.x, py: pos.y,
77
- };
78
- const onMove = (ev: MouseEvent) => {
79
- if (!resizeRef.current) return;
80
- const { edges: ed, ox, oy, pw, ph, px, py } = resizeRef.current;
81
- const dx = ev.clientX - ox;
82
- const dy = ev.clientY - oy;
83
- let nx = px, ny = py, nw = pw, nh = ph;
84
- if (ed.includes('e')) nw = Math.max(minWidth, pw + dx);
85
- if (ed.includes('s')) nh = Math.max(minHeight, ph + dy);
86
- if (ed.includes('w')) { nw = Math.max(minWidth, pw - dx); nx = px + pw - nw; }
87
- if (ed.includes('n')) { nh = Math.max(minHeight, ph - dy); ny = py + ph - nh; }
88
- setSize({ w: nw, h: nh });
89
- setPos({ x: nx, y: ny });
90
- };
91
- const onUp = () => {
92
- resizeRef.current = null;
93
- window.removeEventListener('mousemove', onMove);
94
- window.removeEventListener('mouseup', onUp);
95
- };
96
- window.addEventListener('mousemove', onMove);
97
- window.addEventListener('mouseup', onUp);
98
- };
99
-
100
- return (
101
- <div
102
- className="fp-shell"
103
- style={{ left: pos.x, top: pos.y, width: size.w, height: size.h }}
104
- >
105
- {/* Title bar — drag handle */}
106
- <div className="fp-titlebar" onMouseDown={startMove}>
107
- <span className="fp-title">{title}</span>
108
- <button className="fp-close" onClick={onClose} title="Close">
109
- <svg viewBox="0 0 14 14" width="12" height="12" stroke="currentColor" strokeWidth="1.8" strokeLinecap="round">
110
- <line x1="2" y1="2" x2="12" y2="12" />
111
- <line x1="12" y1="2" x2="2" y2="12" />
112
- </svg>
113
- </button>
114
- </div>
115
-
116
- {/* Content */}
117
- <div className="fp-content">{children}</div>
118
-
119
- {/* Edge resize handles */}
120
- <div className="fp-resize fp-resize-n" onMouseDown={(e) => startResize(e, 'n')} />
121
- <div className="fp-resize fp-resize-s" onMouseDown={(e) => startResize(e, 's')} />
122
- <div className="fp-resize fp-resize-e" onMouseDown={(e) => startResize(e, 'e')} />
123
- <div className="fp-resize fp-resize-w" onMouseDown={(e) => startResize(e, 'w')} />
124
- {/* Corner resize handles */}
125
- <div className="fp-resize fp-resize-nw" onMouseDown={(e) => startResize(e, 'nw')} />
126
- <div className="fp-resize fp-resize-ne" onMouseDown={(e) => startResize(e, 'ne')} />
127
- <div className="fp-resize fp-resize-sw" onMouseDown={(e) => startResize(e, 'sw')} />
128
- <div className="fp-resize fp-resize-se" onMouseDown={(e) => startResize(e, 'se')} />
129
- </div>
130
- );
131
- }