@amcharts/amcharts5 5.6.2 → 5.7.1

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 (326) hide show
  1. package/.internal/charts/stock/StockChart.d.ts +22 -0
  2. package/.internal/charts/stock/StockChart.d.ts.map +1 -1
  3. package/.internal/charts/stock/StockChart.js +64 -12
  4. package/.internal/charts/stock/StockChart.js.map +1 -1
  5. package/.internal/charts/stock/StockChartDefaultTheme.d.ts.map +1 -1
  6. package/.internal/charts/stock/StockChartDefaultTheme.js +64 -2
  7. package/.internal/charts/stock/StockChartDefaultTheme.js.map +1 -1
  8. package/.internal/charts/stock/drawing/CalloutSeries.d.ts.map +1 -1
  9. package/.internal/charts/stock/drawing/CalloutSeries.js +36 -34
  10. package/.internal/charts/stock/drawing/CalloutSeries.js.map +1 -1
  11. package/.internal/charts/stock/drawing/DrawingSeries.d.ts +2 -0
  12. package/.internal/charts/stock/drawing/DrawingSeries.d.ts.map +1 -1
  13. package/.internal/charts/stock/drawing/DrawingSeries.js +3 -0
  14. package/.internal/charts/stock/drawing/DrawingSeries.js.map +1 -1
  15. package/.internal/charts/stock/drawing/IconSeries.d.ts +1 -1
  16. package/.internal/charts/stock/drawing/IconSeries.d.ts.map +1 -1
  17. package/.internal/charts/stock/drawing/IconSeries.js +35 -33
  18. package/.internal/charts/stock/drawing/IconSeries.js.map +1 -1
  19. package/.internal/charts/stock/drawing/LabelSeries.d.ts +1 -1
  20. package/.internal/charts/stock/drawing/LabelSeries.d.ts.map +1 -1
  21. package/.internal/charts/stock/drawing/LabelSeries.js +35 -29
  22. package/.internal/charts/stock/drawing/LabelSeries.js.map +1 -1
  23. package/.internal/charts/stock/indicators/AccumulationDistribution.d.ts.map +1 -1
  24. package/.internal/charts/stock/indicators/AccumulationDistribution.js +4 -3
  25. package/.internal/charts/stock/indicators/AccumulationDistribution.js.map +1 -1
  26. package/.internal/charts/stock/indicators/AccumulativeSwingIndex.d.ts.map +1 -1
  27. package/.internal/charts/stock/indicators/AccumulativeSwingIndex.js +4 -3
  28. package/.internal/charts/stock/indicators/AccumulativeSwingIndex.js.map +1 -1
  29. package/.internal/charts/stock/indicators/Aroon.d.ts.map +1 -1
  30. package/.internal/charts/stock/indicators/Aroon.js +8 -6
  31. package/.internal/charts/stock/indicators/Aroon.js.map +1 -1
  32. package/.internal/charts/stock/indicators/AwesomeOscillator.d.ts.map +1 -1
  33. package/.internal/charts/stock/indicators/AwesomeOscillator.js +6 -4
  34. package/.internal/charts/stock/indicators/AwesomeOscillator.js.map +1 -1
  35. package/.internal/charts/stock/indicators/BollingerBands.d.ts.map +1 -1
  36. package/.internal/charts/stock/indicators/BollingerBands.js +9 -7
  37. package/.internal/charts/stock/indicators/BollingerBands.js.map +1 -1
  38. package/.internal/charts/stock/indicators/ChaikinMoneyFlow.d.ts +2 -3
  39. package/.internal/charts/stock/indicators/ChaikinMoneyFlow.d.ts.map +1 -1
  40. package/.internal/charts/stock/indicators/ChaikinMoneyFlow.js +0 -6
  41. package/.internal/charts/stock/indicators/ChaikinMoneyFlow.js.map +1 -1
  42. package/.internal/charts/stock/indicators/ChaikinOscillator.js +2 -2
  43. package/.internal/charts/stock/indicators/ChaikinOscillator.js.map +1 -1
  44. package/.internal/charts/stock/indicators/ChartIndicator.d.ts.map +1 -1
  45. package/.internal/charts/stock/indicators/ChartIndicator.js.map +1 -1
  46. package/.internal/charts/stock/indicators/DisparityIndex.d.ts.map +1 -1
  47. package/.internal/charts/stock/indicators/DisparityIndex.js +4 -3
  48. package/.internal/charts/stock/indicators/DisparityIndex.js.map +1 -1
  49. package/.internal/charts/stock/indicators/Indicator.d.ts +2 -1
  50. package/.internal/charts/stock/indicators/Indicator.d.ts.map +1 -1
  51. package/.internal/charts/stock/indicators/Indicator.js +13 -8
  52. package/.internal/charts/stock/indicators/Indicator.js.map +1 -1
  53. package/.internal/charts/stock/indicators/MACD.js +1 -1
  54. package/.internal/charts/stock/indicators/MACD.js.map +1 -1
  55. package/.internal/charts/stock/indicators/MovingAverage.js +1 -1
  56. package/.internal/charts/stock/indicators/MovingAverage.js.map +1 -1
  57. package/.internal/charts/stock/indicators/MovingAverageDeviation.js +1 -1
  58. package/.internal/charts/stock/indicators/MovingAverageDeviation.js.map +1 -1
  59. package/.internal/charts/stock/indicators/MovingAverageEnvelope.js +1 -1
  60. package/.internal/charts/stock/indicators/MovingAverageEnvelope.js.map +1 -1
  61. package/.internal/charts/stock/indicators/OnBalanceVolume.d.ts +0 -1
  62. package/.internal/charts/stock/indicators/OnBalanceVolume.d.ts.map +1 -1
  63. package/.internal/charts/stock/indicators/OnBalanceVolume.js +0 -6
  64. package/.internal/charts/stock/indicators/OnBalanceVolume.js.map +1 -1
  65. package/.internal/charts/stock/indicators/OverboughtOversold.d.ts +0 -1
  66. package/.internal/charts/stock/indicators/OverboughtOversold.d.ts.map +1 -1
  67. package/.internal/charts/stock/indicators/OverboughtOversold.js +0 -8
  68. package/.internal/charts/stock/indicators/OverboughtOversold.js.map +1 -1
  69. package/.internal/charts/stock/indicators/RelativeStrengthIndex.js +1 -1
  70. package/.internal/charts/stock/indicators/RelativeStrengthIndex.js.map +1 -1
  71. package/.internal/charts/stock/indicators/StochasticMomentumIndex.js +1 -1
  72. package/.internal/charts/stock/indicators/StochasticMomentumIndex.js.map +1 -1
  73. package/.internal/charts/stock/indicators/StochasticOscillator.js +1 -1
  74. package/.internal/charts/stock/indicators/StochasticOscillator.js.map +1 -1
  75. package/.internal/charts/stock/indicators/Trix.js +1 -1
  76. package/.internal/charts/stock/indicators/Trix.js.map +1 -1
  77. package/.internal/charts/stock/indicators/VWAP.d.ts +0 -1
  78. package/.internal/charts/stock/indicators/VWAP.d.ts.map +1 -1
  79. package/.internal/charts/stock/indicators/VWAP.js +20 -22
  80. package/.internal/charts/stock/indicators/VWAP.js.map +1 -1
  81. package/.internal/charts/stock/indicators/Volume.js +1 -1
  82. package/.internal/charts/stock/indicators/Volume.js.map +1 -1
  83. package/.internal/charts/stock/indicators/VolumeProfile.d.ts +85 -0
  84. package/.internal/charts/stock/indicators/VolumeProfile.d.ts.map +1 -0
  85. package/.internal/charts/stock/indicators/VolumeProfile.js +458 -0
  86. package/.internal/charts/stock/indicators/VolumeProfile.js.map +1 -0
  87. package/.internal/charts/stock/toolbar/DataSaveControl.d.ts +75 -0
  88. package/.internal/charts/stock/toolbar/DataSaveControl.d.ts.map +1 -0
  89. package/.internal/charts/stock/toolbar/DataSaveControl.js +204 -0
  90. package/.internal/charts/stock/toolbar/DataSaveControl.js.map +1 -0
  91. package/.internal/charts/stock/toolbar/DrawingControl.d.ts.map +1 -1
  92. package/.internal/charts/stock/toolbar/DrawingControl.js.map +1 -1
  93. package/.internal/charts/stock/toolbar/Dropdown.d.ts.map +1 -1
  94. package/.internal/charts/stock/toolbar/Dropdown.js +5 -1
  95. package/.internal/charts/stock/toolbar/Dropdown.js.map +1 -1
  96. package/.internal/charts/stock/toolbar/DropdownList.d.ts +29 -0
  97. package/.internal/charts/stock/toolbar/DropdownList.d.ts.map +1 -1
  98. package/.internal/charts/stock/toolbar/DropdownList.js +19 -2
  99. package/.internal/charts/stock/toolbar/DropdownList.js.map +1 -1
  100. package/.internal/charts/stock/toolbar/DropdownListControl.d.ts +29 -0
  101. package/.internal/charts/stock/toolbar/DropdownListControl.d.ts.map +1 -1
  102. package/.internal/charts/stock/toolbar/DropdownListControl.js +2 -1
  103. package/.internal/charts/stock/toolbar/DropdownListControl.js.map +1 -1
  104. package/.internal/charts/stock/toolbar/IndicatorControl.d.ts +1 -1
  105. package/.internal/charts/stock/toolbar/IndicatorControl.d.ts.map +1 -1
  106. package/.internal/charts/stock/toolbar/IndicatorControl.js +10 -1
  107. package/.internal/charts/stock/toolbar/IndicatorControl.js.map +1 -1
  108. package/.internal/charts/stock/toolbar/PeriodSelector.js +1 -1
  109. package/.internal/charts/stock/toolbar/PeriodSelector.js.map +1 -1
  110. package/.internal/charts/stock/toolbar/SettingsControl.d.ts +21 -0
  111. package/.internal/charts/stock/toolbar/SettingsControl.d.ts.map +1 -1
  112. package/.internal/charts/stock/toolbar/SettingsControl.js +33 -3
  113. package/.internal/charts/stock/toolbar/SettingsControl.js.map +1 -1
  114. package/.internal/charts/stock/toolbar/StockControl.d.ts.map +1 -1
  115. package/.internal/charts/stock/toolbar/StockControl.js +1 -0
  116. package/.internal/charts/stock/toolbar/StockControl.js.map +1 -1
  117. package/.internal/charts/stock/toolbar/StockIcons.d.ts.map +1 -1
  118. package/.internal/charts/stock/toolbar/StockIcons.js +1 -0
  119. package/.internal/charts/stock/toolbar/StockIcons.js.map +1 -1
  120. package/.internal/charts/xy/XYCursor.d.ts +2 -1
  121. package/.internal/charts/xy/XYCursor.d.ts.map +1 -1
  122. package/.internal/charts/xy/XYCursor.js.map +1 -1
  123. package/.internal/charts/xy/axes/Axis.d.ts +5 -0
  124. package/.internal/charts/xy/axes/Axis.d.ts.map +1 -1
  125. package/.internal/charts/xy/axes/Axis.js +111 -109
  126. package/.internal/charts/xy/axes/Axis.js.map +1 -1
  127. package/.internal/charts/xy/axes/AxisRendererX.d.ts.map +1 -1
  128. package/.internal/charts/xy/axes/AxisRendererX.js +4 -1
  129. package/.internal/charts/xy/axes/AxisRendererX.js.map +1 -1
  130. package/.internal/charts/xy/axes/DateAxis.d.ts.map +1 -1
  131. package/.internal/charts/xy/axes/DateAxis.js +40 -35
  132. package/.internal/charts/xy/axes/DateAxis.js.map +1 -1
  133. package/.internal/charts/xy/axes/GaplessDateAxis.d.ts +13 -1
  134. package/.internal/charts/xy/axes/GaplessDateAxis.d.ts.map +1 -1
  135. package/.internal/charts/xy/axes/GaplessDateAxis.js +116 -75
  136. package/.internal/charts/xy/axes/GaplessDateAxis.js.map +1 -1
  137. package/.internal/charts/xy/series/XYSeries.d.ts +1 -0
  138. package/.internal/charts/xy/series/XYSeries.d.ts.map +1 -1
  139. package/.internal/charts/xy/series/XYSeries.js +4 -2
  140. package/.internal/charts/xy/series/XYSeries.js.map +1 -1
  141. package/.internal/core/Classes.d.ts +4 -0
  142. package/.internal/core/Classes.d.ts.map +1 -1
  143. package/.internal/core/Classes.js.map +1 -1
  144. package/.internal/core/Registry.js +1 -1
  145. package/.internal/core/Registry.js.map +1 -1
  146. package/.internal/core/render/Series.d.ts.map +1 -1
  147. package/.internal/core/render/Series.js +3 -0
  148. package/.internal/core/render/Series.js.map +1 -1
  149. package/.internal/core/render/SpriteResizer.d.ts +1 -1
  150. package/.internal/core/render/SpriteResizer.d.ts.map +1 -1
  151. package/.internal/core/render/SpriteResizer.js.map +1 -1
  152. package/.internal/core/render/backend/CanvasRenderer.d.ts +1 -0
  153. package/.internal/core/render/backend/CanvasRenderer.d.ts.map +1 -1
  154. package/.internal/core/render/backend/CanvasRenderer.js +4 -0
  155. package/.internal/core/render/backend/CanvasRenderer.js.map +1 -1
  156. package/.internal/core/render/backend/Renderer.d.ts +1 -0
  157. package/.internal/core/render/backend/Renderer.d.ts.map +1 -1
  158. package/.internal/core/render/backend/Renderer.js.map +1 -1
  159. package/.internal/core/util/Time.d.ts +5 -0
  160. package/.internal/core/util/Time.d.ts.map +1 -1
  161. package/.internal/core/util/Time.js +10 -0
  162. package/.internal/core/util/Time.js.map +1 -1
  163. package/.internal/core/util/Utils.d.ts +0 -8
  164. package/.internal/core/util/Utils.d.ts.map +1 -1
  165. package/.internal/core/util/Utils.js +0 -24
  166. package/.internal/core/util/Utils.js.map +1 -1
  167. package/.internal/plugins/json/Classes-script.d.ts +4 -0
  168. package/.internal/plugins/json/Classes-script.d.ts.map +1 -1
  169. package/.internal/plugins/json/Classes-script.js +2 -0
  170. package/.internal/plugins/json/Classes-script.js.map +1 -1
  171. package/.internal/plugins/json/Classes.d.ts +4 -0
  172. package/.internal/plugins/json/Classes.d.ts.map +1 -1
  173. package/.internal/plugins/json/Classes.js +2 -0
  174. package/.internal/plugins/json/Classes.js.map +1 -1
  175. package/.internal/plugins/json/Serializer.d.ts +6 -0
  176. package/.internal/plugins/json/Serializer.d.ts.map +1 -1
  177. package/.internal/plugins/json/Serializer.js +3 -2
  178. package/.internal/plugins/json/Serializer.js.map +1 -1
  179. package/CHANGELOG.md +37 -0
  180. package/examples/javascript/flow-arc-horizontal/package.json +1 -1
  181. package/examples/javascript/flow-arc-vertical/package.json +1 -1
  182. package/examples/javascript/flow-chord/package.json +1 -1
  183. package/examples/javascript/flow-chord-directed/package.json +1 -1
  184. package/examples/javascript/flow-chord-non-ribbon/package.json +1 -1
  185. package/examples/javascript/flow-sankey/package.json +1 -1
  186. package/examples/javascript/gauge/package.json +1 -1
  187. package/examples/javascript/gauge-bands/package.json +1 -1
  188. package/examples/javascript/hierarchy-force-directed/package.json +1 -1
  189. package/examples/javascript/hierarchy-pack/package.json +1 -1
  190. package/examples/javascript/hierarchy-partition/package.json +1 -1
  191. package/examples/javascript/hierarchy-sunburst/package.json +1 -1
  192. package/examples/javascript/hierarchy-tree/package.json +1 -1
  193. package/examples/javascript/hierarchy-treemap/package.json +1 -1
  194. package/examples/javascript/hierarchy-voronoi-treemap/package.json +1 -1
  195. package/examples/javascript/jest/package.json +1 -1
  196. package/examples/javascript/json-pie/package.json +1 -1
  197. package/examples/javascript/json-xy/package.json +1 -1
  198. package/examples/javascript/map-animating-along-lines/package.json +1 -1
  199. package/examples/javascript/map-clustered-points/package.json +1 -1
  200. package/examples/javascript/map-day-and-night/package.json +1 -1
  201. package/examples/javascript/map-globe-rotate-to-country/package.json +1 -1
  202. package/examples/javascript/map-globe-with-projected-circles/package.json +1 -1
  203. package/examples/javascript/map-with-bubbles/package.json +1 -1
  204. package/examples/javascript/map-zoom-to-country/package.json +1 -1
  205. package/examples/javascript/misc-40-charts/package.json +1 -1
  206. package/examples/javascript/misc-microchart-grid/package.json +1 -1
  207. package/examples/javascript/pie-chart/package.json +1 -1
  208. package/examples/javascript/pie-donut-chart/package.json +1 -1
  209. package/examples/javascript/pie-variable-radius/package.json +1 -1
  210. package/examples/javascript/radar-column-iwatch-style/package.json +1 -1
  211. package/examples/javascript/radar-heat-map/package.json +1 -1
  212. package/examples/javascript/radar-line/package.json +1 -1
  213. package/examples/javascript/radar-time-line/package.json +1 -1
  214. package/examples/javascript/sliced-funnel/package.json +1 -1
  215. package/examples/javascript/sliced-pictorial-stacked/package.json +1 -1
  216. package/examples/javascript/sliced-pyramid/package.json +1 -1
  217. package/examples/javascript/stock-chart/package.json +1 -1
  218. package/examples/javascript/stock-chart-comparing-stocks/package.json +1 -1
  219. package/examples/javascript/stock-chart-data-granularity/package.json +1 -1
  220. package/examples/javascript/stock-chart-data-grouping/package.json +1 -1
  221. package/examples/javascript/stock-chart-intraday/package.json +1 -1
  222. package/examples/javascript/stock-chart-live/package.json +1 -1
  223. package/examples/javascript/stock-chart-volume-separate-panel/package.json +1 -1
  224. package/examples/javascript/venn-diagram/package.json +1 -1
  225. package/examples/javascript/wordcloud-with-data/package.json +1 -1
  226. package/examples/javascript/wordcloud-with-text/package.json +1 -1
  227. package/examples/javascript/xy-100-percent-stacked-column/package.json +1 -1
  228. package/examples/javascript/xy-animated-bullet-at-the-end-of-the-series/package.json +1 -1
  229. package/examples/javascript/xy-bubble/package.json +1 -1
  230. package/examples/javascript/xy-candlestick/package.json +1 -1
  231. package/examples/javascript/xy-clustered-column/package.json +1 -1
  232. package/examples/javascript/xy-column/package.json +1 -1
  233. package/examples/javascript/xy-comparing-series-google-analytics-style/package.json +1 -1
  234. package/examples/javascript/xy-data-grouping/package.json +1 -1
  235. package/examples/javascript/xy-draggable-range/package.json +1 -1
  236. package/examples/javascript/xy-drawing-series-with-mouse-or-touch/package.json +1 -1
  237. package/examples/javascript/xy-dumbbell plot/package.json +1 -1
  238. package/examples/javascript/xy-evenly-spaced-date-axis/package.json +1 -1
  239. package/examples/javascript/xy-line/package.json +1 -1
  240. package/examples/javascript/xy-line-highlight-on-legend-hover/package.json +1 -1
  241. package/examples/javascript/xy-live-data/package.json +1 -1
  242. package/examples/javascript/xy-multiple-synced-value-axes/package.json +1 -1
  243. package/examples/javascript/xy-ohlc/package.json +1 -1
  244. package/examples/javascript/xy-real-time-data-sorting/package.json +1 -1
  245. package/examples/javascript/xy-smoothed-line/package.json +1 -1
  246. package/examples/javascript/xy-stacked-and-clustered-column/package.json +1 -1
  247. package/examples/javascript/xy-stacked-column/package.json +1 -1
  248. package/examples/javascript/xy-stacked-step/package.json +1 -1
  249. package/examples/javascript/xy-stock/package.json +1 -1
  250. package/examples/javascript/xy-stock-comparing/package.json +1 -1
  251. package/examples/typescript/flow-arc-horizontal/package.json +1 -1
  252. package/examples/typescript/flow-arc-vertical/package.json +1 -1
  253. package/examples/typescript/flow-chord/package.json +1 -1
  254. package/examples/typescript/flow-chord-directed/package.json +1 -1
  255. package/examples/typescript/flow-chord-non-ribbon/package.json +1 -1
  256. package/examples/typescript/flow-sankey/package.json +1 -1
  257. package/examples/typescript/gauge/package.json +1 -1
  258. package/examples/typescript/gauge-bands/package.json +1 -1
  259. package/examples/typescript/hierarchy-force-directed/package.json +1 -1
  260. package/examples/typescript/hierarchy-pack/package.json +1 -1
  261. package/examples/typescript/hierarchy-partition/package.json +1 -1
  262. package/examples/typescript/hierarchy-sunburst/package.json +1 -1
  263. package/examples/typescript/hierarchy-tree/package.json +1 -1
  264. package/examples/typescript/hierarchy-treemap/package.json +1 -1
  265. package/examples/typescript/hierarchy-voronoi-treemap/package.json +1 -1
  266. package/examples/typescript/jest/package.json +1 -1
  267. package/examples/typescript/json-pie/package.json +1 -1
  268. package/examples/typescript/json-xy/package.json +1 -1
  269. package/examples/typescript/map-animating-along-lines/package.json +1 -1
  270. package/examples/typescript/map-clustered-points/package.json +1 -1
  271. package/examples/typescript/map-day-and-night/package.json +1 -1
  272. package/examples/typescript/map-globe-rotate-to-country/package.json +1 -1
  273. package/examples/typescript/map-globe-with-projected-circles/package.json +1 -1
  274. package/examples/typescript/map-with-bubbles/package.json +1 -1
  275. package/examples/typescript/map-zoom-to-country/package.json +1 -1
  276. package/examples/typescript/misc-40-charts/package.json +1 -1
  277. package/examples/typescript/misc-microchart-grid/package.json +1 -1
  278. package/examples/typescript/pie-chart/package.json +1 -1
  279. package/examples/typescript/pie-donut-chart/package.json +1 -1
  280. package/examples/typescript/pie-variable-radius/package.json +1 -1
  281. package/examples/typescript/radar-column-iwatch-style/package.json +1 -1
  282. package/examples/typescript/radar-heat-map/package.json +1 -1
  283. package/examples/typescript/radar-line/package.json +1 -1
  284. package/examples/typescript/radar-time-line/package.json +1 -1
  285. package/examples/typescript/sliced-funnel/package.json +1 -1
  286. package/examples/typescript/sliced-pictorial-stacked/package.json +1 -1
  287. package/examples/typescript/sliced-pyramid/package.json +1 -1
  288. package/examples/typescript/stock-chart/package.json +1 -1
  289. package/examples/typescript/stock-chart-comparing-stocks/package.json +1 -1
  290. package/examples/typescript/stock-chart-data-granularity/package.json +1 -1
  291. package/examples/typescript/stock-chart-data-grouping/package.json +1 -1
  292. package/examples/typescript/stock-chart-intraday/package.json +1 -1
  293. package/examples/typescript/stock-chart-live/package.json +1 -1
  294. package/examples/typescript/stock-chart-volume-separate-panel/package.json +1 -1
  295. package/examples/typescript/venn-diagram/package.json +1 -1
  296. package/examples/typescript/wordcloud-with-data/package.json +1 -1
  297. package/examples/typescript/wordcloud-with-text/package.json +1 -1
  298. package/examples/typescript/xy-100-percent-stacked-column/package.json +1 -1
  299. package/examples/typescript/xy-animated-bullet-at-the-end-of-the-series/package.json +1 -1
  300. package/examples/typescript/xy-bubble/package.json +1 -1
  301. package/examples/typescript/xy-candlestick/package.json +1 -1
  302. package/examples/typescript/xy-clustered-column/package.json +1 -1
  303. package/examples/typescript/xy-column/package.json +1 -1
  304. package/examples/typescript/xy-comparing-series-google-analytics-style/package.json +1 -1
  305. package/examples/typescript/xy-data-grouping/package.json +1 -1
  306. package/examples/typescript/xy-draggable-range/package.json +1 -1
  307. package/examples/typescript/xy-drawing-series-with-mouse-or-touch/package.json +1 -1
  308. package/examples/typescript/xy-dumbbell plot/package.json +1 -1
  309. package/examples/typescript/xy-evenly-spaced-date-axis/package.json +1 -1
  310. package/examples/typescript/xy-line/package.json +1 -1
  311. package/examples/typescript/xy-line-highlight-on-legend-hover/package.json +1 -1
  312. package/examples/typescript/xy-live-data/package.json +1 -1
  313. package/examples/typescript/xy-multiple-synced-value-axes/package.json +1 -1
  314. package/examples/typescript/xy-ohlc/package.json +1 -1
  315. package/examples/typescript/xy-real-time-data-sorting/package.json +1 -1
  316. package/examples/typescript/xy-smoothed-line/package.json +1 -1
  317. package/examples/typescript/xy-stacked-and-clustered-column/package.json +1 -1
  318. package/examples/typescript/xy-stacked-column/package.json +1 -1
  319. package/examples/typescript/xy-stacked-step/package.json +1 -1
  320. package/examples/typescript/xy-stock/package.json +1 -1
  321. package/examples/typescript/xy-stock-comparing/package.json +1 -1
  322. package/package.json +1 -1
  323. package/stock.d.ts +2 -0
  324. package/stock.d.ts.map +1 -1
  325. package/stock.js +2 -0
  326. package/stock.js.map +1 -1
@@ -0,0 +1,458 @@
1
+ import { AxisRendererX } from "../../xy/axes/AxisRendererX";
2
+ import { ValueAxis } from "../../xy/axes/ValueAxis";
3
+ import { Indicator } from "./Indicator";
4
+ import { ColumnSeries } from "../../xy/series/ColumnSeries";
5
+ import { percent } from "../../../core/util/Percent";
6
+ import * as $type from "../../../core/util/Type";
7
+ /**
8
+ * An implementation of a Volume Profile indicator for a [[StockChart]].
9
+ *
10
+ * @see {@link https://www.amcharts.com/docs/v5/charts/stock/indicators/} for more info
11
+ * @since 5.7.0
12
+ */
13
+ export class VolumeProfile extends Indicator {
14
+ constructor() {
15
+ super(...arguments);
16
+ Object.defineProperty(this, "_editableSettings", {
17
+ enumerable: true,
18
+ configurable: true,
19
+ writable: true,
20
+ value: [{
21
+ key: "countType",
22
+ name: this.root.language.translateAny("Count"),
23
+ type: "dropdown",
24
+ options: [
25
+ { value: "rows", text: this.root.language.translateAny("number of rows") },
26
+ { value: "ticks", text: this.root.language.translateAny("ticks per row") }
27
+ ]
28
+ }, {
29
+ key: "count",
30
+ name: this.root.language.translateAny("Count"),
31
+ type: "number"
32
+ }, {
33
+ key: "valueArea",
34
+ name: this.root.language.translateAny("Value Area"),
35
+ type: "number"
36
+ }, {
37
+ key: "upColor",
38
+ name: this.root.language.translateAny("Up volume"),
39
+ type: "color"
40
+ }, {
41
+ key: "downColor",
42
+ name: this.root.language.translateAny("Down volume"),
43
+ type: "color"
44
+ }, {
45
+ key: "axisWidth",
46
+ name: this.root.language.translateAny("Width %"),
47
+ type: "number"
48
+ }]
49
+ });
50
+ Object.defineProperty(this, "xAxis", {
51
+ enumerable: true,
52
+ configurable: true,
53
+ writable: true,
54
+ value: void 0
55
+ });
56
+ Object.defineProperty(this, "upSeries", {
57
+ enumerable: true,
58
+ configurable: true,
59
+ writable: true,
60
+ value: void 0
61
+ });
62
+ Object.defineProperty(this, "_previousColumn", {
63
+ enumerable: true,
64
+ configurable: true,
65
+ writable: true,
66
+ value: void 0
67
+ });
68
+ }
69
+ _afterNew() {
70
+ super._afterNew();
71
+ const volumeSeries = this.get("volumeSeries");
72
+ const stockSeries = this.get("stockSeries");
73
+ if (volumeSeries) {
74
+ const chart = stockSeries.chart;
75
+ const root = this._root;
76
+ if (chart) {
77
+ const yAxis = stockSeries.get("yAxis");
78
+ const panelXAxis = stockSeries.get("xAxis");
79
+ panelXAxis.on("start", () => {
80
+ this.markDataDirty();
81
+ });
82
+ panelXAxis.on("end", () => {
83
+ this.markDataDirty();
84
+ });
85
+ const xRenderer = AxisRendererX.new(root, {});
86
+ xRenderer.grid.template.set("forceHidden", true);
87
+ xRenderer.labels.template.set("forceHidden", true);
88
+ this.xAxis = chart.xAxes.push(ValueAxis.new(root, {
89
+ zoomable: false,
90
+ strictMinMax: true,
91
+ panX: false,
92
+ panY: false,
93
+ renderer: xRenderer
94
+ }));
95
+ if (yAxis.get("renderer").get("opposite")) {
96
+ xRenderer.set("inversed", true);
97
+ this.xAxis.setAll({
98
+ x: percent(100),
99
+ centerX: percent(100)
100
+ });
101
+ }
102
+ this.series = chart.series.unshift(ColumnSeries.new(root, {
103
+ xAxis: this.xAxis,
104
+ yAxis: yAxis,
105
+ valueXField: "down",
106
+ openValueXField: "xOpen",
107
+ openValueYField: "yOpen",
108
+ valueYField: "y",
109
+ calculateAggregates: true,
110
+ themeTags: ["indicator", "volumeprofile"]
111
+ }));
112
+ this.upSeries = chart.series.unshift(ColumnSeries.new(root, {
113
+ xAxis: this.xAxis,
114
+ yAxis: yAxis,
115
+ valueXField: "total",
116
+ openValueXField: "down",
117
+ openValueYField: "yOpen",
118
+ valueYField: "y",
119
+ calculateAggregates: true,
120
+ themeTags: ["indicator", "volumeprofile"]
121
+ }));
122
+ this.upSeries.setPrivate("doNotUpdateLegend", true);
123
+ this.series.setPrivate("doNotUpdateLegend", true);
124
+ this.upSeries.setPrivate("baseValueSeries", stockSeries);
125
+ this.series.setPrivate("baseValueSeries", stockSeries);
126
+ this._handleLegend(this.series);
127
+ this._addInteractivity(this.series);
128
+ this._addInteractivity(this.upSeries);
129
+ }
130
+ }
131
+ }
132
+ _addInteractivity(series) {
133
+ series.columns.template.events.on("pointerover", (e) => {
134
+ let dataItem = e.target.dataItem;
135
+ if (dataItem) {
136
+ if (dataItem.component == this.upSeries) {
137
+ dataItem = this.series.dataItems[this.upSeries.dataItems.indexOf(dataItem)];
138
+ if (dataItem) {
139
+ const column = dataItem.get("graphics");
140
+ if (column) {
141
+ column.hover();
142
+ this._previousColumn = column;
143
+ }
144
+ }
145
+ }
146
+ else {
147
+ dataItem = this.upSeries.dataItems[this.series.dataItems.indexOf(dataItem)];
148
+ if (dataItem) {
149
+ const column = dataItem.get("graphics");
150
+ if (column) {
151
+ column.hover();
152
+ this._previousColumn = column;
153
+ }
154
+ }
155
+ }
156
+ this.series.updateLegendValue(dataItem);
157
+ }
158
+ });
159
+ series.columns.template.events.on("pointerout", () => {
160
+ this.series.updateLegendValue(undefined);
161
+ if (this._previousColumn) {
162
+ this._previousColumn.unhover();
163
+ }
164
+ });
165
+ series.columns.template.adapters.add("fillOpacity", (fillOpacity, target) => {
166
+ const dataItem = target.dataItem;
167
+ if (dataItem) {
168
+ const dataContext = dataItem.dataContext;
169
+ if (dataContext) {
170
+ if (dataContext.area) {
171
+ return this.get("valueAreaOpacity", .7);
172
+ }
173
+ }
174
+ }
175
+ return fillOpacity;
176
+ });
177
+ }
178
+ _updateChildren() {
179
+ if (this.series) {
180
+ super._updateChildren();
181
+ if (this.isDirty("count") || this.isDirty("countType") || this.isDirty("valueArea")) {
182
+ this.markDataDirty();
183
+ }
184
+ if (this.isDirty("upColor")) {
185
+ const upColor = this.get("upColor");
186
+ this.upSeries.set("fill", upColor);
187
+ this.upSeries.set("stroke", upColor);
188
+ this.setCustomData("upColor", upColor);
189
+ }
190
+ if (this.isDirty("downColor")) {
191
+ const downColor = this.get("downColor");
192
+ this.series.set("fill", downColor);
193
+ this.series.set("stroke", downColor);
194
+ this.setCustomData("downColor", downColor);
195
+ }
196
+ if (this.isDirty("axisWidth")) {
197
+ this.xAxis.set("width", percent(this.get("axisWidth", 40)));
198
+ }
199
+ }
200
+ }
201
+ /**
202
+ * @ignore
203
+ */
204
+ prepareData() {
205
+ const volumeSeries = this.get("volumeSeries");
206
+ const stockSeries = this.get("stockSeries");
207
+ if (volumeSeries && this.series) {
208
+ let startIndex = volumeSeries.startIndex();
209
+ let endIndex = volumeSeries.endIndex();
210
+ const count = this.get("count", 20);
211
+ const type = this.get("countType");
212
+ let step = 1;
213
+ let min = Infinity;
214
+ let max = -Infinity;
215
+ for (let i = startIndex; i < endIndex; i++) {
216
+ const dataItem = stockSeries.dataItems[i];
217
+ if (dataItem) {
218
+ const close = dataItem.get("valueY");
219
+ if ($type.isNumber(close)) {
220
+ if (close < min) {
221
+ min = close;
222
+ }
223
+ if (close > max) {
224
+ max = close;
225
+ }
226
+ }
227
+ }
228
+ }
229
+ if (min != Infinity) {
230
+ let rows;
231
+ if (type == "ticks") {
232
+ step = count / 100;
233
+ min = Math.floor(min / step) * step;
234
+ max = Math.ceil(max / step) * step;
235
+ rows = (max - min) / step;
236
+ }
237
+ else {
238
+ step = (max - min) / count;
239
+ rows = count;
240
+ }
241
+ const rowDataDown = [];
242
+ const rowDataUp = [];
243
+ for (let i = 0; i < rows; i++) {
244
+ rowDataDown[i] = 0;
245
+ rowDataUp[i] = 0;
246
+ }
247
+ let previousDataItem;
248
+ for (let i = startIndex; i < endIndex; i++) {
249
+ const dataItem = stockSeries.dataItems[i];
250
+ const volumeDataItem = volumeSeries.dataItems[i];
251
+ if (dataItem && volumeDataItem) {
252
+ const close = dataItem.get("valueY");
253
+ const volume = volumeDataItem.get("valueY");
254
+ if ($type.isNumber(close) && $type.isNumber(volume)) {
255
+ let index = Math.floor((close - min) / step);
256
+ if (index == count) {
257
+ index = count - 1;
258
+ }
259
+ if ($type.isNumber(index)) {
260
+ if (previousDataItem && previousDataItem.get("valueY", close) < close) {
261
+ rowDataDown[index] += volume;
262
+ }
263
+ else {
264
+ rowDataUp[index] += volume;
265
+ }
266
+ }
267
+ }
268
+ previousDataItem = dataItem;
269
+ }
270
+ }
271
+ const dataDown = [];
272
+ let sum = 0;
273
+ for (let i = 0; i < rows; i++) {
274
+ let total = rowDataUp[i] + rowDataDown[i];
275
+ sum += total;
276
+ dataDown.push({
277
+ yOpen: min + i * step,
278
+ y: min + (i + 1) * step,
279
+ up: rowDataUp[i],
280
+ down: rowDataDown[i],
281
+ total: total,
282
+ xOpen: 0,
283
+ area: false
284
+ });
285
+ }
286
+ let len = this.series.data.length;
287
+ if (len && len == dataDown.length) {
288
+ for (let i = 0; i < len; i++) {
289
+ this.series.data.setIndex(i, dataDown[i]);
290
+ }
291
+ }
292
+ else {
293
+ this.series.data.setAll(dataDown);
294
+ }
295
+ const dataUp = [];
296
+ let highest = 0;
297
+ let hi = 0;
298
+ for (let i = 0; i < rows; i++) {
299
+ let total = rowDataUp[i] + rowDataDown[i];
300
+ dataUp.push({
301
+ yOpen: min + i * step,
302
+ y: min + (i + 1) * step,
303
+ up: rowDataUp[i],
304
+ down: rowDataDown[i],
305
+ total: total,
306
+ area: false
307
+ });
308
+ if (total > highest) {
309
+ highest = total;
310
+ hi = i;
311
+ }
312
+ }
313
+ let valueArea = sum * this.get("valueArea", 70) / 100;
314
+ let area = highest;
315
+ let cd = 1;
316
+ let cu = 1;
317
+ let dlen = dataUp.length;
318
+ dataUp[hi].area = true;
319
+ dataDown[hi].area = true;
320
+ /*
321
+ // with two rows
322
+ while (area < valueArea) {
323
+ let rowAbove1 = hi + cu;
324
+ let rowAbove2 = hi + cu + 1;
325
+
326
+ let sumAbove = 0
327
+ if (rowAbove1 < dlen) {
328
+ sumAbove += dataUp[rowAbove1].total;
329
+ }
330
+ if (rowAbove2 < dlen) {
331
+ sumAbove += dataUp[rowAbove2].total;
332
+ }
333
+
334
+ let rowBelow1 = hi - cd;
335
+ let rowBelow2 = hi - cd - 1;
336
+
337
+ let sumBelow = 0
338
+ if (rowBelow1 >= 0) {
339
+ sumBelow += dataUp[rowBelow1].total;
340
+ }
341
+ if (rowBelow2 >= 0) {
342
+ sumBelow += dataUp[rowBelow2].total;
343
+ }
344
+
345
+ if (sumBelow <= sumAbove) {
346
+ area += sumAbove;
347
+ if (rowAbove1 < dlen) {
348
+ dataDown[rowAbove1].area = true;
349
+ dataUp[rowAbove1].area = true;
350
+ cu++;
351
+ }
352
+ if (rowAbove2 < dlen) {
353
+ dataDown[rowAbove2].area = true;
354
+ dataUp[rowAbove2].area = true;
355
+ cu++;
356
+ }
357
+ }
358
+ else {
359
+ area += sumBelow;
360
+ if (rowBelow1 >= 0) {
361
+ dataDown[rowBelow1].area = true;
362
+ dataUp[rowBelow1].area = true;
363
+ cd++;
364
+ }
365
+ if (rowBelow2 >= 0) {
366
+ dataDown[rowBelow2].area = true;
367
+ dataUp[rowBelow2].area = true;
368
+ cd++;
369
+ }
370
+ }
371
+
372
+ if (sumBelow == 0) {
373
+ cd++;
374
+ }
375
+ if (sumAbove == 0) {
376
+ cu++;
377
+ }
378
+
379
+ if ((cd > dlen && cu > dlen)) {
380
+ break;
381
+ }
382
+
383
+ }
384
+ */
385
+ // single row
386
+ while (area < valueArea) {
387
+ let rowAbove1 = hi + cu;
388
+ let sumAbove = 0;
389
+ if (rowAbove1 < dlen) {
390
+ sumAbove += dataUp[rowAbove1].total;
391
+ }
392
+ let rowBelow1 = hi - cd;
393
+ let sumBelow = 0;
394
+ if (rowBelow1 >= 0) {
395
+ sumBelow += dataUp[rowBelow1].total;
396
+ }
397
+ if (sumBelow <= sumAbove) {
398
+ area += sumAbove;
399
+ if (rowAbove1 < dlen) {
400
+ dataDown[rowAbove1].area = true;
401
+ dataUp[rowAbove1].area = true;
402
+ cu++;
403
+ }
404
+ }
405
+ else {
406
+ area += sumBelow;
407
+ if (rowBelow1 >= 0) {
408
+ dataDown[rowBelow1].area = true;
409
+ dataUp[rowBelow1].area = true;
410
+ cd++;
411
+ }
412
+ }
413
+ if (sumBelow == 0) {
414
+ cd++;
415
+ }
416
+ if (sumAbove == 0) {
417
+ cu++;
418
+ }
419
+ if ((cd > dlen && cu > dlen)) {
420
+ break;
421
+ }
422
+ }
423
+ area = Math.ceil(area);
424
+ len = this.upSeries.data.length;
425
+ if (len > 0 && len == dataUp.length) {
426
+ for (let i = 0; i < len; i++) {
427
+ this.upSeries.data.setIndex(i, dataUp[i]);
428
+ }
429
+ }
430
+ else {
431
+ this.upSeries.data.setAll(dataUp);
432
+ }
433
+ }
434
+ }
435
+ }
436
+ _dispose() {
437
+ super._dispose();
438
+ if (this.upSeries) {
439
+ this.upSeries.dispose();
440
+ }
441
+ if (this.xAxis) {
442
+ this.xAxis.dispose();
443
+ }
444
+ }
445
+ }
446
+ Object.defineProperty(VolumeProfile, "className", {
447
+ enumerable: true,
448
+ configurable: true,
449
+ writable: true,
450
+ value: "VolumeProfile"
451
+ });
452
+ Object.defineProperty(VolumeProfile, "classNames", {
453
+ enumerable: true,
454
+ configurable: true,
455
+ writable: true,
456
+ value: Indicator.classNames.concat([VolumeProfile.className])
457
+ });
458
+ //# sourceMappingURL=VolumeProfile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VolumeProfile.js","sourceRoot":"","sources":["../../../../../../src/.internal/charts/stock/indicators/VolumeProfile.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAsF,MAAM,aAAa,CAAC;AAC5H,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAC;AAErD,OAAO,KAAK,KAAK,MAAM,yBAAyB,CAAC;AA4DjD;;;;;GAKG;AACH,MAAM,OAAO,aAAc,SAAQ,SAAS;IAA5C;;QAaC;;;;mBAAwD,CAAC;oBACxD,GAAG,EAAE,WAAW;oBAChB,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,OAAO,CAAC;oBAC9C,IAAI,EAAE,UAAU;oBAChB,OAAO,EAAE;wBACR,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,gBAAgB,CAAC,EAAE;wBAC1E,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,eAAe,CAAC,EAAE;qBAC1E;iBACD,EAAE;oBACF,GAAG,EAAE,OAAO;oBACZ,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,OAAO,CAAC;oBAC9C,IAAI,EAAE,QAAQ;iBACd,EAAE;oBACF,GAAG,EAAE,WAAW;oBAChB,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,YAAY,CAAC;oBACnD,IAAI,EAAE,QAAQ;iBACd,EAAE;oBACF,GAAG,EAAE,SAAS;oBACd,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,WAAW,CAAC;oBAClD,IAAI,EAAE,OAAO;iBACb,EAAE;oBACF,GAAG,EAAE,WAAW;oBAChB,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,aAAa,CAAC;oBACpD,IAAI,EAAE,OAAO;iBACb,EAAE;oBACF,GAAG,EAAE,WAAW;oBAChB,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,SAAS,CAAC;oBAChD,IAAI,EAAE,QAAQ;iBACd,CAAC;WAAC;QAEH;;;;;WAAwC;QAExC;;;;;WAA+B;QAE/B;;;;;WAAqC;IAmbtC,CAAC;IAjbU,SAAS;QAClB,KAAK,CAAC,SAAS,EAAE,CAAC;QAElB,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC9C,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;QAC5C,IAAI,YAAY,EAAE;YACjB,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC;YAChC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;YAExB,IAAI,KAAK,EAAE;gBACV,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,CAAC,OAAO,CAAQ,CAAC;gBAC9C,MAAM,UAAU,GAAG,WAAW,CAAC,GAAG,CAAC,OAAO,CAA4B,CAAC;gBAEvE,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;oBAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;gBACtB,CAAC,CAAC,CAAA;gBACF,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE;oBACzB,IAAI,CAAC,aAAa,EAAE,CAAC;gBACtB,CAAC,CAAC,CAAA;gBAEF,MAAM,SAAS,GAAG,aAAa,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBAC9C,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;gBACjD,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;gBAEnD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE;oBACjD,QAAQ,EAAE,KAAK;oBACf,YAAY,EAAE,IAAI;oBAClB,IAAI,EAAE,KAAK;oBACX,IAAI,EAAE,KAAK;oBACX,QAAQ,EAAE,SAAS;iBACnB,CAAC,CAAC,CAAC;gBAEJ,IAAI,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE;oBAC1C,SAAS,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;oBAChC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;wBACjB,CAAC,EAAE,OAAO,CAAC,GAAG,CAAC;wBACf,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC;qBACrB,CAAC,CAAA;iBACF;gBAED,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,EAAE;oBACzD,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,KAAK,EAAE,KAAK;oBACZ,WAAW,EAAE,MAAM;oBACnB,eAAe,EAAE,OAAO;oBACxB,eAAe,EAAE,OAAO;oBACxB,WAAW,EAAE,GAAG;oBAChB,mBAAmB,EAAE,IAAI;oBACzB,SAAS,EAAE,CAAC,WAAW,EAAE,eAAe,CAAC;iBACzC,CAAC,CAAC,CAAA;gBAGH,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,EAAE;oBAC3D,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,KAAK,EAAE,KAAK;oBACZ,WAAW,EAAE,OAAO;oBACpB,eAAe,EAAE,MAAM;oBACvB,eAAe,EAAE,OAAO;oBACxB,WAAW,EAAE,GAAG;oBAChB,mBAAmB,EAAE,IAAI;oBACzB,SAAS,EAAE,CAAC,WAAW,EAAE,eAAe,CAAC;iBACzC,CAAC,CAAC,CAAA;gBAEH,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;gBACpD,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;gBAElD,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,iBAAiB,EAAE,WAAW,CAAC,CAAC;gBACzD,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,iBAAiB,EAAE,WAAW,CAAC,CAAC;gBAEvD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAEhC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBACpC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACtC;SACD;IACF,CAAC;IAES,iBAAiB,CAAC,MAAoB;QAC/C,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE,EAAE;YACtD,IAAI,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC;YAEjC,IAAI,QAAQ,EAAE;gBACb,IAAI,QAAQ,CAAC,SAAS,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACxC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;oBAC5E,IAAI,QAAQ,EAAE;wBACb,MAAM,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAiB,CAAC,CAAC;wBAC/C,IAAI,MAAM,EAAE;4BACX,MAAM,CAAC,KAAK,EAAE,CAAC;4BACf,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;yBAC9B;qBACD;iBACD;qBACI;oBACJ,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;oBAC5E,IAAI,QAAQ,EAAE;wBACb,MAAM,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAiB,CAAC,CAAC;wBAC/C,IAAI,MAAM,EAAE;4BACX,MAAM,CAAC,KAAK,EAAE,CAAC;4BACf,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC;yBAC9B;qBACD;iBACD;gBAED,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;aACxC;QACF,CAAC,CAAC,CAAA;QAEF,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,YAAY,EAAE,GAAG,EAAE;YACpD,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;YACzC,IAAI,IAAI,CAAC,eAAe,EAAE;gBACzB,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;aAC/B;QACF,CAAC,CAAC,CAAA;QAEF,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,WAAW,EAAE,MAAM,EAAE,EAAE;YAC3E,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;YACjC,IAAI,QAAQ,EAAE;gBACb,MAAM,WAAW,GAAG,QAAQ,CAAC,WAAkB,CAAC;gBAChD,IAAI,WAAW,EAAE;oBAChB,IAAI,WAAW,CAAC,IAAI,EAAE;wBACrB,OAAO,IAAI,CAAC,GAAG,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC;qBACxC;iBACD;aACD;YACD,OAAO,WAAW,CAAC;QACpB,CAAC,CAAC,CAAA;IACH,CAAC;IAEM,eAAe;QACrB,IAAI,IAAI,CAAC,MAAM,EAAE;YAChB,KAAK,CAAC,eAAe,EAAE,CAAC;YAExB,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;gBACpF,IAAI,CAAC,aAAa,EAAE,CAAC;aACrB;YAED,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;gBACpC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;gBACnC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;gBACrC,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;aACvC;YAED,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;gBAC9B,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;gBACxC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;gBACnC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;gBACrC,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;aAC3C;YAED,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE;gBAC9B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;aAC5D;SACD;IACF,CAAC;IAED;;OAEG;IACI,WAAW;QACjB,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC9C,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;QAE5C,IAAI,YAAY,IAAI,IAAI,CAAC,MAAM,EAAE;YAChC,IAAI,UAAU,GAAG,YAAY,CAAC,UAAU,EAAE,CAAC;YAC3C,IAAI,QAAQ,GAAG,YAAY,CAAC,QAAQ,EAAE,CAAC;YAEvC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;YACpC,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;YACnC,IAAI,IAAI,GAAG,CAAC,CAAC;YAEb,IAAI,GAAG,GAAG,QAAQ,CAAC;YACnB,IAAI,GAAG,GAAG,CAAC,QAAQ,CAAC;YAEpB,KAAK,IAAI,CAAC,GAAG,UAAU,EAAE,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,EAAE;gBAC3C,MAAM,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;gBAC1C,IAAI,QAAQ,EAAE;oBACb,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;oBACrC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;wBAC1B,IAAI,KAAK,GAAG,GAAG,EAAE;4BAChB,GAAG,GAAG,KAAK,CAAC;yBACZ;wBAED,IAAI,KAAK,GAAG,GAAG,EAAE;4BAChB,GAAG,GAAG,KAAK,CAAC;yBACZ;qBACD;iBACD;aACD;YAED,IAAI,GAAG,IAAI,QAAQ,EAAE;gBAEpB,IAAI,IAAY,CAAC;gBACjB,IAAI,IAAI,IAAI,OAAO,EAAE;oBACpB,IAAI,GAAG,KAAK,GAAG,GAAG,CAAC;oBACnB,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;oBACpC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;oBACnC,IAAI,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC;iBAC1B;qBACI;oBACJ,IAAI,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC;oBAC3B,IAAI,GAAG,KAAK,CAAC;iBACb;gBAED,MAAM,WAAW,GAAkB,EAAE,CAAC;gBACtC,MAAM,SAAS,GAAkB,EAAE,CAAC;gBAEpC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;oBAC9B,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;oBACnB,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;iBACjB;gBAED,IAAI,gBAAgB,CAAC;gBACrB,KAAK,IAAI,CAAC,GAAG,UAAU,EAAE,CAAC,GAAG,QAAQ,EAAE,CAAC,EAAE,EAAE;oBAC3C,MAAM,QAAQ,GAAG,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;oBAC1C,MAAM,cAAc,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;oBACjD,IAAI,QAAQ,IAAI,cAAc,EAAE;wBAC/B,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;wBACrC,MAAM,MAAM,GAAG,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;wBAE5C,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;4BACpD,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;4BAC7C,IAAI,KAAK,IAAI,KAAK,EAAE;gCACnB,KAAK,GAAG,KAAK,GAAG,CAAC,CAAC;6BAClB;4BAED,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;gCAC1B,IAAI,gBAAgB,IAAI,gBAAgB,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,GAAG,KAAK,EAAE;oCACtE,WAAW,CAAC,KAAK,CAAC,IAAI,MAAM,CAAC;iCAC7B;qCACI;oCACJ,SAAS,CAAC,KAAK,CAAC,IAAI,MAAM,CAAC;iCAC3B;6BACD;yBACD;wBACD,gBAAgB,GAAG,QAAQ,CAAC;qBAC5B;iBACD;gBAED,MAAM,QAAQ,GAAG,EAAE,CAAC;gBACpB,IAAI,GAAG,GAAG,CAAC,CAAC;gBACZ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;oBAC9B,IAAI,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;oBAC1C,GAAG,IAAI,KAAK,CAAC;oBAEb,QAAQ,CAAC,IAAI,CAAC;wBACb,KAAK,EAAE,GAAG,GAAG,CAAC,GAAG,IAAI;wBACrB,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI;wBACvB,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC;wBAChB,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC;wBACpB,KAAK,EAAE,KAAK;wBACZ,KAAK,EAAE,CAAC;wBACR,IAAI,EAAE,KAAK;qBACX,CAAC,CAAA;iBACF;gBAED,IAAI,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;gBAClC,IAAI,GAAG,IAAI,GAAG,IAAI,QAAQ,CAAC,MAAM,EAAE;oBAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;wBAC7B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC1C;iBACD;qBACI;oBACJ,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;iBAClC;gBAED,MAAM,MAAM,GAAG,EAAE,CAAC;gBAElB,IAAI,OAAO,GAAG,CAAC,CAAC;gBAChB,IAAI,EAAE,GAAG,CAAC,CAAC;gBAEX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;oBAC9B,IAAI,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;oBAC1C,MAAM,CAAC,IAAI,CAAC;wBACX,KAAK,EAAE,GAAG,GAAG,CAAC,GAAG,IAAI;wBACrB,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI;wBACvB,EAAE,EAAE,SAAS,CAAC,CAAC,CAAC;wBAChB,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC;wBACpB,KAAK,EAAE,KAAK;wBACZ,IAAI,EAAE,KAAK;qBACX,CAAC,CAAA;oBAEF,IAAI,KAAK,GAAG,OAAO,EAAE;wBACpB,OAAO,GAAG,KAAK,CAAC;wBAChB,EAAE,GAAG,CAAC,CAAC;qBACP;iBACD;gBAED,IAAI,SAAS,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC;gBACtD,IAAI,IAAI,GAAG,OAAO,CAAC;gBAEnB,IAAI,EAAE,GAAG,CAAC,CAAC;gBACX,IAAI,EAAE,GAAG,CAAC,CAAC;gBACX,IAAI,IAAI,GAAG,MAAM,CAAC,MAAM,CAAC;gBAEzB,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC;gBACvB,QAAQ,CAAC,EAAE,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC;gBAEzB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAgEE;gBAEF,aAAa;gBACb,OAAO,IAAI,GAAG,SAAS,EAAE;oBACxB,IAAI,SAAS,GAAG,EAAE,GAAG,EAAE,CAAC;oBACxB,IAAI,QAAQ,GAAG,CAAC,CAAA;oBAChB,IAAI,SAAS,GAAG,IAAI,EAAE;wBACrB,QAAQ,IAAI,MAAM,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC;qBACpC;oBAED,IAAI,SAAS,GAAG,EAAE,GAAG,EAAE,CAAC;oBAExB,IAAI,QAAQ,GAAG,CAAC,CAAA;oBAChB,IAAI,SAAS,IAAI,CAAC,EAAE;wBACnB,QAAQ,IAAI,MAAM,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC;qBACpC;oBAED,IAAI,QAAQ,IAAI,QAAQ,EAAE;wBACzB,IAAI,IAAI,QAAQ,CAAC;wBACjB,IAAI,SAAS,GAAG,IAAI,EAAE;4BACrB,QAAQ,CAAC,SAAS,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC;4BAChC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC;4BAC9B,EAAE,EAAE,CAAC;yBACL;qBACD;yBACI;wBACJ,IAAI,IAAI,QAAQ,CAAC;wBACjB,IAAI,SAAS,IAAI,CAAC,EAAE;4BACnB,QAAQ,CAAC,SAAS,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC;4BAChC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,GAAG,IAAI,CAAC;4BAC9B,EAAE,EAAE,CAAC;yBACL;qBACD;oBAED,IAAI,QAAQ,IAAI,CAAC,EAAE;wBAClB,EAAE,EAAE,CAAC;qBACL;oBACD,IAAI,QAAQ,IAAI,CAAC,EAAE;wBAClB,EAAE,EAAE,CAAC;qBACL;oBAED,IAAI,CAAC,EAAE,GAAG,IAAI,IAAI,EAAE,GAAG,IAAI,CAAC,EAAE;wBAC7B,MAAM;qBACN;iBACD;gBAED,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAEvB,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC;gBAChC,IAAI,GAAG,GAAG,CAAC,IAAI,GAAG,IAAI,MAAM,CAAC,MAAM,EAAE;oBACpC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;wBAC7B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC1C;iBACD;qBACI;oBACJ,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;iBAClC;aACD;SACD;IACF,CAAC;IAES,QAAQ;QACjB,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;SACxB;QAED,IAAI,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;SACrB;IACF,CAAC;;AAheD;;;;WAAkC,eAAe;GAAC;AAClD;;;;WAA0C,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;GAAC","sourcesContent":["import type { DateAxis } from \"../../xy/axes/DateAxis\";\r\nimport type { Color } from \"../../../core/util/Color\";\r\nimport type { Graphics } from \"../../../core/render/Graphics\";\r\nimport type { XYSeries } from \"../../xy/series/XYSeries\";\r\n\r\nimport { AxisRendererX } from \"../../xy/axes/AxisRendererX\";\r\nimport { ValueAxis } from \"../../xy/axes/ValueAxis\";\r\nimport { Indicator, IIndicatorSettings, IIndicatorPrivate, IIndicatorEvents, IIndicatorEditableSetting } from \"./Indicator\";\r\nimport { ColumnSeries } from \"../../xy/series/ColumnSeries\";\r\nimport { percent } from \"../../../core/util/Percent\";\r\n\r\nimport * as $type from \"../../../core/util/Type\";\r\n\r\nexport interface IVolumeProfileSettings extends IIndicatorSettings {\r\n\t/**\r\n\t * Volume up color.\r\n\t */\r\n\tupColor?: Color;\r\n\r\n\t/**\r\n\t * Volume down color.\r\n\t */\r\n\tdownColor?: Color;\r\n\r\n\t/**\r\n\t * Type of count\r\n\t * @todo: what if translated in options?\r\n\t */\r\n\tcountType?: \"rows\" | \"ticks\";\r\n\r\n\t/**\r\n\t * Number of rows or number of ticks, depending on the countType.\r\n\t *\r\n\t * @default 24\r\n\t */\r\n\tcount?: number;\r\n\r\n\t/**\r\n\t * Max width of columns in percent (%).\r\n\t * \r\n\t * @default 40\r\n\t */\r\n\taxisWidth?: number;\r\n\r\n\t/**\r\n\t * Specifies what percentage of all volume for the trading session should\r\n\t * be highlighted by Value Area.\r\n\t * \r\n\t * @default 70\r\n\t */\r\n\tvalueArea?: number;\r\n\r\n\t/**\r\n\t * Opacity of columns which fall withing value area.\r\n\t * \r\n\t * @default .7\r\n\t */\r\n\tvalueAreaOpacity?: number;\r\n\r\n\t/**\r\n\t * Chart's main volume series.\r\n\t */\r\n\tvolumeSeries: XYSeries;\r\n}\r\n\r\nexport interface IVolumeProfilePrivate extends IIndicatorPrivate {\r\n}\r\n\r\nexport interface IVolumeProfileEvents extends IIndicatorEvents {\r\n}\r\n\r\n/**\r\n * An implementation of a Volume Profile indicator for a [[StockChart]].\r\n *\r\n * @see {@link https://www.amcharts.com/docs/v5/charts/stock/indicators/} for more info\r\n * @since 5.7.0\r\n */\r\nexport class VolumeProfile extends Indicator {\r\n\tpublic static className: string = \"VolumeProfile\";\r\n\tpublic static classNames: Array<string> = Indicator.classNames.concat([VolumeProfile.className]);\r\n\r\n\tdeclare public _settings: IVolumeProfileSettings;\r\n\tdeclare public _privateSettings: IVolumeProfilePrivate;\r\n\tdeclare public _events: IVolumeProfileEvents;\r\n\r\n\t/**\r\n\t * Indicator series.\r\n\t */\r\n\tdeclare public series: ColumnSeries;\r\n\r\n\tpublic _editableSettings: IIndicatorEditableSetting[] = [{\r\n\t\tkey: \"countType\",\r\n\t\tname: this.root.language.translateAny(\"Count\"),\r\n\t\ttype: \"dropdown\",\r\n\t\toptions: [\r\n\t\t\t{ value: \"rows\", text: this.root.language.translateAny(\"number of rows\") },\r\n\t\t\t{ value: \"ticks\", text: this.root.language.translateAny(\"ticks per row\") }\r\n\t\t]\r\n\t}, {\r\n\t\tkey: \"count\",\r\n\t\tname: this.root.language.translateAny(\"Count\"),\r\n\t\ttype: \"number\"\r\n\t}, {\r\n\t\tkey: \"valueArea\",\r\n\t\tname: this.root.language.translateAny(\"Value Area\"),\r\n\t\ttype: \"number\"\r\n\t}, {\r\n\t\tkey: \"upColor\",\r\n\t\tname: this.root.language.translateAny(\"Up volume\"),\r\n\t\ttype: \"color\"\r\n\t}, {\r\n\t\tkey: \"downColor\",\r\n\t\tname: this.root.language.translateAny(\"Down volume\"),\r\n\t\ttype: \"color\"\r\n\t}, {\r\n\t\tkey: \"axisWidth\",\r\n\t\tname: this.root.language.translateAny(\"Width %\"),\r\n\t\ttype: \"number\"\r\n\t}];\r\n\r\n\tpublic xAxis!: ValueAxis<AxisRendererX>;\r\n\r\n\tpublic upSeries!: ColumnSeries;\r\n\r\n\tprotected _previousColumn?: Graphics;\r\n\r\n\tprotected _afterNew() {\r\n\t\tsuper._afterNew();\r\n\r\n\t\tconst volumeSeries = this.get(\"volumeSeries\");\r\n\t\tconst stockSeries = this.get(\"stockSeries\");\r\n\t\tif (volumeSeries) {\r\n\t\t\tconst chart = stockSeries.chart;\r\n\t\t\tconst root = this._root;\r\n\r\n\t\t\tif (chart) {\r\n\t\t\t\tconst yAxis = stockSeries.get(\"yAxis\") as any;\r\n\t\t\t\tconst panelXAxis = stockSeries.get(\"xAxis\") as DateAxis<AxisRendererX>;\r\n\r\n\t\t\t\tpanelXAxis.on(\"start\", () => {\r\n\t\t\t\t\tthis.markDataDirty();\r\n\t\t\t\t})\r\n\t\t\t\tpanelXAxis.on(\"end\", () => {\r\n\t\t\t\t\tthis.markDataDirty();\r\n\t\t\t\t})\r\n\r\n\t\t\t\tconst xRenderer = AxisRendererX.new(root, {});\r\n\t\t\t\txRenderer.grid.template.set(\"forceHidden\", true);\r\n\t\t\t\txRenderer.labels.template.set(\"forceHidden\", true);\r\n\r\n\t\t\t\tthis.xAxis = chart.xAxes.push(ValueAxis.new(root, {\r\n\t\t\t\t\tzoomable: false,\r\n\t\t\t\t\tstrictMinMax: true,\r\n\t\t\t\t\tpanX: false,\r\n\t\t\t\t\tpanY: false,\r\n\t\t\t\t\trenderer: xRenderer\r\n\t\t\t\t}));\r\n\r\n\t\t\t\tif (yAxis.get(\"renderer\").get(\"opposite\")) {\r\n\t\t\t\t\txRenderer.set(\"inversed\", true);\r\n\t\t\t\t\tthis.xAxis.setAll({\r\n\t\t\t\t\t\tx: percent(100),\r\n\t\t\t\t\t\tcenterX: percent(100)\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\r\n\t\t\t\tthis.series = chart.series.unshift(ColumnSeries.new(root, {\r\n\t\t\t\t\txAxis: this.xAxis,\r\n\t\t\t\t\tyAxis: yAxis,\r\n\t\t\t\t\tvalueXField: \"down\",\r\n\t\t\t\t\topenValueXField: \"xOpen\",\r\n\t\t\t\t\topenValueYField: \"yOpen\",\r\n\t\t\t\t\tvalueYField: \"y\",\r\n\t\t\t\t\tcalculateAggregates: true,\r\n\t\t\t\t\tthemeTags: [\"indicator\", \"volumeprofile\"]\r\n\t\t\t\t}))\r\n\r\n\r\n\t\t\t\tthis.upSeries = chart.series.unshift(ColumnSeries.new(root, {\r\n\t\t\t\t\txAxis: this.xAxis,\r\n\t\t\t\t\tyAxis: yAxis,\r\n\t\t\t\t\tvalueXField: \"total\",\r\n\t\t\t\t\topenValueXField: \"down\",\r\n\t\t\t\t\topenValueYField: \"yOpen\",\r\n\t\t\t\t\tvalueYField: \"y\",\r\n\t\t\t\t\tcalculateAggregates: true,\r\n\t\t\t\t\tthemeTags: [\"indicator\", \"volumeprofile\"]\r\n\t\t\t\t}))\r\n\r\n\t\t\t\tthis.upSeries.setPrivate(\"doNotUpdateLegend\", true);\r\n\t\t\t\tthis.series.setPrivate(\"doNotUpdateLegend\", true);\r\n\r\n\t\t\t\tthis.upSeries.setPrivate(\"baseValueSeries\", stockSeries);\r\n\t\t\t\tthis.series.setPrivate(\"baseValueSeries\", stockSeries);\r\n\r\n\t\t\t\tthis._handleLegend(this.series);\r\n\r\n\t\t\t\tthis._addInteractivity(this.series);\r\n\t\t\t\tthis._addInteractivity(this.upSeries);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tprotected _addInteractivity(series: ColumnSeries) {\r\n\t\tseries.columns.template.events.on(\"pointerover\", (e) => {\r\n\t\t\tlet dataItem = e.target.dataItem;\r\n\r\n\t\t\tif (dataItem) {\r\n\t\t\t\tif (dataItem.component == this.upSeries) {\r\n\t\t\t\t\tdataItem = this.series.dataItems[this.upSeries.dataItems.indexOf(dataItem)];\r\n\t\t\t\t\tif (dataItem) {\r\n\t\t\t\t\t\tconst column = dataItem.get(\"graphics\" as any);\r\n\t\t\t\t\t\tif (column) {\r\n\t\t\t\t\t\t\tcolumn.hover();\r\n\t\t\t\t\t\t\tthis._previousColumn = column;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\telse {\r\n\t\t\t\t\tdataItem = this.upSeries.dataItems[this.series.dataItems.indexOf(dataItem)];\r\n\t\t\t\t\tif (dataItem) {\r\n\t\t\t\t\t\tconst column = dataItem.get(\"graphics\" as any);\r\n\t\t\t\t\t\tif (column) {\r\n\t\t\t\t\t\t\tcolumn.hover();\r\n\t\t\t\t\t\t\tthis._previousColumn = column;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tthis.series.updateLegendValue(dataItem);\r\n\t\t\t}\r\n\t\t})\r\n\r\n\t\tseries.columns.template.events.on(\"pointerout\", () => {\r\n\t\t\tthis.series.updateLegendValue(undefined);\r\n\t\t\tif (this._previousColumn) {\r\n\t\t\t\tthis._previousColumn.unhover();\r\n\t\t\t}\r\n\t\t})\r\n\r\n\t\tseries.columns.template.adapters.add(\"fillOpacity\", (fillOpacity, target) => {\r\n\t\t\tconst dataItem = target.dataItem;\r\n\t\t\tif (dataItem) {\r\n\t\t\t\tconst dataContext = dataItem.dataContext as any;\r\n\t\t\t\tif (dataContext) {\r\n\t\t\t\t\tif (dataContext.area) {\r\n\t\t\t\t\t\treturn this.get(\"valueAreaOpacity\", .7);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t\treturn fillOpacity;\r\n\t\t})\r\n\t}\r\n\r\n\tpublic _updateChildren(): void {\r\n\t\tif (this.series) {\r\n\t\t\tsuper._updateChildren();\r\n\r\n\t\t\tif (this.isDirty(\"count\") || this.isDirty(\"countType\") || this.isDirty(\"valueArea\")) {\r\n\t\t\t\tthis.markDataDirty();\r\n\t\t\t}\r\n\r\n\t\t\tif (this.isDirty(\"upColor\")) {\r\n\t\t\t\tconst upColor = this.get(\"upColor\");\r\n\t\t\t\tthis.upSeries.set(\"fill\", upColor);\r\n\t\t\t\tthis.upSeries.set(\"stroke\", upColor);\r\n\t\t\t\tthis.setCustomData(\"upColor\", upColor);\r\n\t\t\t}\r\n\r\n\t\t\tif (this.isDirty(\"downColor\")) {\r\n\t\t\t\tconst downColor = this.get(\"downColor\");\r\n\t\t\t\tthis.series.set(\"fill\", downColor);\r\n\t\t\t\tthis.series.set(\"stroke\", downColor);\r\n\t\t\t\tthis.setCustomData(\"downColor\", downColor);\r\n\t\t\t}\r\n\r\n\t\t\tif (this.isDirty(\"axisWidth\")) {\r\n\t\t\t\tthis.xAxis.set(\"width\", percent(this.get(\"axisWidth\", 40)));\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t/**\r\n\t * @ignore\r\n\t */\r\n\tpublic prepareData() {\r\n\t\tconst volumeSeries = this.get(\"volumeSeries\");\r\n\t\tconst stockSeries = this.get(\"stockSeries\");\r\n\r\n\t\tif (volumeSeries && this.series) {\r\n\t\t\tlet startIndex = volumeSeries.startIndex();\r\n\t\t\tlet endIndex = volumeSeries.endIndex();\r\n\r\n\t\t\tconst count = this.get(\"count\", 20);\r\n\t\t\tconst type = this.get(\"countType\");\r\n\t\t\tlet step = 1;\r\n\r\n\t\t\tlet min = Infinity;\r\n\t\t\tlet max = -Infinity;\r\n\r\n\t\t\tfor (let i = startIndex; i < endIndex; i++) {\r\n\t\t\t\tconst dataItem = stockSeries.dataItems[i];\r\n\t\t\t\tif (dataItem) {\r\n\t\t\t\t\tconst close = dataItem.get(\"valueY\");\r\n\t\t\t\t\tif ($type.isNumber(close)) {\r\n\t\t\t\t\t\tif (close < min) {\r\n\t\t\t\t\t\t\tmin = close;\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\tif (close > max) {\r\n\t\t\t\t\t\t\tmax = close;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t}\r\n\r\n\t\t\tif (min != Infinity) {\r\n\r\n\t\t\t\tlet rows: number;\r\n\t\t\t\tif (type == \"ticks\") {\r\n\t\t\t\t\tstep = count / 100;\r\n\t\t\t\t\tmin = Math.floor(min / step) * step;\r\n\t\t\t\t\tmax = Math.ceil(max / step) * step;\r\n\t\t\t\t\trows = (max - min) / step;\r\n\t\t\t\t}\r\n\t\t\t\telse {\r\n\t\t\t\t\tstep = (max - min) / count;\r\n\t\t\t\t\trows = count;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tconst rowDataDown: Array<number> = [];\r\n\t\t\t\tconst rowDataUp: Array<number> = [];\r\n\r\n\t\t\t\tfor (let i = 0; i < rows; i++) {\r\n\t\t\t\t\trowDataDown[i] = 0;\r\n\t\t\t\t\trowDataUp[i] = 0;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tlet previousDataItem;\r\n\t\t\t\tfor (let i = startIndex; i < endIndex; i++) {\r\n\t\t\t\t\tconst dataItem = stockSeries.dataItems[i];\r\n\t\t\t\t\tconst volumeDataItem = volumeSeries.dataItems[i];\r\n\t\t\t\t\tif (dataItem && volumeDataItem) {\r\n\t\t\t\t\t\tconst close = dataItem.get(\"valueY\");\r\n\t\t\t\t\t\tconst volume = volumeDataItem.get(\"valueY\");\r\n\r\n\t\t\t\t\t\tif ($type.isNumber(close) && $type.isNumber(volume)) {\r\n\t\t\t\t\t\t\tlet index = Math.floor((close - min) / step);\r\n\t\t\t\t\t\t\tif (index == count) {\r\n\t\t\t\t\t\t\t\tindex = count - 1;\r\n\t\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\t\tif ($type.isNumber(index)) {\r\n\t\t\t\t\t\t\t\tif (previousDataItem && previousDataItem.get(\"valueY\", close) < close) {\r\n\t\t\t\t\t\t\t\t\trowDataDown[index] += volume;\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\telse {\r\n\t\t\t\t\t\t\t\t\trowDataUp[index] += volume;\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tpreviousDataItem = dataItem;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tconst dataDown = [];\r\n\t\t\t\tlet sum = 0;\r\n\t\t\t\tfor (let i = 0; i < rows; i++) {\r\n\t\t\t\t\tlet total = rowDataUp[i] + rowDataDown[i];\r\n\t\t\t\t\tsum += total;\r\n\r\n\t\t\t\t\tdataDown.push({\r\n\t\t\t\t\t\tyOpen: min + i * step,\r\n\t\t\t\t\t\ty: min + (i + 1) * step,\r\n\t\t\t\t\t\tup: rowDataUp[i],\r\n\t\t\t\t\t\tdown: rowDataDown[i],\r\n\t\t\t\t\t\ttotal: total,\r\n\t\t\t\t\t\txOpen: 0,\r\n\t\t\t\t\t\tarea: false\r\n\t\t\t\t\t})\r\n\t\t\t\t}\r\n\r\n\t\t\t\tlet len = this.series.data.length;\r\n\t\t\t\tif (len && len == dataDown.length) {\r\n\t\t\t\t\tfor (let i = 0; i < len; i++) {\r\n\t\t\t\t\t\tthis.series.data.setIndex(i, dataDown[i]);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\telse {\r\n\t\t\t\t\tthis.series.data.setAll(dataDown);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tconst dataUp = [];\r\n\r\n\t\t\t\tlet highest = 0;\r\n\t\t\t\tlet hi = 0;\r\n\r\n\t\t\t\tfor (let i = 0; i < rows; i++) {\r\n\t\t\t\t\tlet total = rowDataUp[i] + rowDataDown[i];\r\n\t\t\t\t\tdataUp.push({\r\n\t\t\t\t\t\tyOpen: min + i * step,\r\n\t\t\t\t\t\ty: min + (i + 1) * step,\r\n\t\t\t\t\t\tup: rowDataUp[i],\r\n\t\t\t\t\t\tdown: rowDataDown[i],\r\n\t\t\t\t\t\ttotal: total,\r\n\t\t\t\t\t\tarea: false\r\n\t\t\t\t\t})\r\n\r\n\t\t\t\t\tif (total > highest) {\r\n\t\t\t\t\t\thighest = total;\r\n\t\t\t\t\t\thi = i;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tlet valueArea = sum * this.get(\"valueArea\", 70) / 100;\r\n\t\t\t\tlet area = highest;\r\n\r\n\t\t\t\tlet cd = 1;\r\n\t\t\t\tlet cu = 1;\r\n\t\t\t\tlet dlen = dataUp.length;\r\n\r\n\t\t\t\tdataUp[hi].area = true;\r\n\t\t\t\tdataDown[hi].area = true;\r\n\r\n\t\t\t\t/* \r\n\t\t\t\t// with two rows\r\n\t\t\t\twhile (area < valueArea) {\r\n\t\t\t\t\tlet rowAbove1 = hi + cu;\r\n\t\t\t\t\tlet rowAbove2 = hi + cu + 1;\r\n\r\n\t\t\t\t\tlet sumAbove = 0\r\n\t\t\t\t\tif (rowAbove1 < dlen) {\r\n\t\t\t\t\t\tsumAbove += dataUp[rowAbove1].total;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (rowAbove2 < dlen) {\r\n\t\t\t\t\t\tsumAbove += dataUp[rowAbove2].total;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tlet rowBelow1 = hi - cd;\r\n\t\t\t\t\tlet rowBelow2 = hi - cd - 1;\r\n\r\n\t\t\t\t\tlet sumBelow = 0\r\n\t\t\t\t\tif (rowBelow1 >= 0) {\r\n\t\t\t\t\t\tsumBelow += dataUp[rowBelow1].total;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (rowBelow2 >= 0) {\r\n\t\t\t\t\t\tsumBelow += dataUp[rowBelow2].total;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif (sumBelow <= sumAbove) {\r\n\t\t\t\t\t\tarea += sumAbove;\r\n\t\t\t\t\t\tif (rowAbove1 < dlen) {\r\n\t\t\t\t\t\t\tdataDown[rowAbove1].area = true;\r\n\t\t\t\t\t\t\tdataUp[rowAbove1].area = true;\r\n\t\t\t\t\t\t\tcu++;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (rowAbove2 < dlen) {\r\n\t\t\t\t\t\t\tdataDown[rowAbove2].area = true;\r\n\t\t\t\t\t\t\tdataUp[rowAbove2].area = true;\r\n\t\t\t\t\t\t\tcu++;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t\telse {\r\n\t\t\t\t\t\tarea += sumBelow;\r\n\t\t\t\t\t\tif (rowBelow1 >= 0) {\r\n\t\t\t\t\t\t\tdataDown[rowBelow1].area = true;\r\n\t\t\t\t\t\t\tdataUp[rowBelow1].area = true;\r\n\t\t\t\t\t\t\tcd++;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (rowBelow2 >= 0) {\r\n\t\t\t\t\t\t\tdataDown[rowBelow2].area = true;\r\n\t\t\t\t\t\t\tdataUp[rowBelow2].area = true;\r\n\t\t\t\t\t\t\tcd++;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif (sumBelow == 0) {\r\n\t\t\t\t\t\tcd++;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (sumAbove == 0) {\r\n\t\t\t\t\t\tcu++;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif ((cd > dlen && cu > dlen)) {\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t}\r\n\t\t\t\t*/\r\n\r\n\t\t\t\t// single row\r\n\t\t\t\twhile (area < valueArea) {\r\n\t\t\t\t\tlet rowAbove1 = hi + cu;\r\n\t\t\t\t\tlet sumAbove = 0\r\n\t\t\t\t\tif (rowAbove1 < dlen) {\r\n\t\t\t\t\t\tsumAbove += dataUp[rowAbove1].total;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tlet rowBelow1 = hi - cd;\r\n\r\n\t\t\t\t\tlet sumBelow = 0\r\n\t\t\t\t\tif (rowBelow1 >= 0) {\r\n\t\t\t\t\t\tsumBelow += dataUp[rowBelow1].total;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif (sumBelow <= sumAbove) {\r\n\t\t\t\t\t\tarea += sumAbove;\r\n\t\t\t\t\t\tif (rowAbove1 < dlen) {\r\n\t\t\t\t\t\t\tdataDown[rowAbove1].area = true;\r\n\t\t\t\t\t\t\tdataUp[rowAbove1].area = true;\r\n\t\t\t\t\t\t\tcu++;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t\telse {\r\n\t\t\t\t\t\tarea += sumBelow;\r\n\t\t\t\t\t\tif (rowBelow1 >= 0) {\r\n\t\t\t\t\t\t\tdataDown[rowBelow1].area = true;\r\n\t\t\t\t\t\t\tdataUp[rowBelow1].area = true;\r\n\t\t\t\t\t\t\tcd++;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif (sumBelow == 0) {\r\n\t\t\t\t\t\tcd++;\r\n\t\t\t\t\t}\r\n\t\t\t\t\tif (sumAbove == 0) {\r\n\t\t\t\t\t\tcu++;\r\n\t\t\t\t\t}\r\n\r\n\t\t\t\t\tif ((cd > dlen && cu > dlen)) {\r\n\t\t\t\t\t\tbreak;\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\r\n\t\t\t\tarea = Math.ceil(area);\r\n\r\n\t\t\t\tlen = this.upSeries.data.length;\r\n\t\t\t\tif (len > 0 && len == dataUp.length) {\r\n\t\t\t\t\tfor (let i = 0; i < len; i++) {\r\n\t\t\t\t\t\tthis.upSeries.data.setIndex(i, dataUp[i]);\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t\telse {\r\n\t\t\t\t\tthis.upSeries.data.setAll(dataUp);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tprotected _dispose() {\r\n\t\tsuper._dispose();\r\n\t\tif (this.upSeries) {\r\n\t\t\tthis.upSeries.dispose();\r\n\t\t}\r\n\r\n\t\tif (this.xAxis) {\r\n\t\t\tthis.xAxis.dispose();\r\n\t\t}\r\n\t}\r\n}"]}
@@ -0,0 +1,75 @@
1
+ import type { IDropdownListItem } from "./DropdownList";
2
+ import { DropdownListControl, IDropdownListControlSettings, IDropdownListControlPrivate, IDropdownListControlEvents } from "./DropdownListControl";
3
+ import { DrawingControl } from "./DrawingControl";
4
+ import { IndicatorControl } from "./IndicatorControl";
5
+ export interface IDataSaveControlItem extends IDropdownListItem {
6
+ }
7
+ export interface IDataSaveControlSettings extends IDropdownListControlSettings {
8
+ /**
9
+ * If set to `true`, all changes to chart's drawings and indicators will be
10
+ * automatically saved to browser local storage and restored on next load.
11
+ *
12
+ * @default false
13
+ */
14
+ autoSave?: boolean;
15
+ /**
16
+ * A unique indentifier for local storage.
17
+ *
18
+ * Will try to use chart's container ID if not set.
19
+ *
20
+ * Consider setting it if you have multipl [[StockChart]] on the same page.
21
+ */
22
+ storageId?: string;
23
+ }
24
+ export interface IDataSaveControlPrivate extends IDropdownListControlPrivate {
25
+ drawingControl?: DrawingControl;
26
+ indicatorControl?: IndicatorControl;
27
+ storageId?: string;
28
+ }
29
+ export interface IDataSaveControlEvents extends IDropdownListControlEvents {
30
+ /**
31
+ * Invoked when drawing/indicator data is serialized and saved to local
32
+ * storage.
33
+ */
34
+ saved: {
35
+ drawings: string;
36
+ indicators: string;
37
+ };
38
+ /**
39
+ * Invoked when drawing/indicator data is loaded from local storage and
40
+ * restored on chart.
41
+ */
42
+ restored: {
43
+ drawings: string;
44
+ indicators: string;
45
+ };
46
+ /**
47
+ * Invoked when local storage is cleared.
48
+ */
49
+ cleared: {};
50
+ }
51
+ /**
52
+ * A control that can be used to serialize indicators and drawings, save them
53
+ * to local storage, and restore as needed.
54
+ *
55
+ * @see {@link https://www.amcharts.com/docs/v5/charts/stock/toolbar/data-save-control/} for more info
56
+ * @since 5.7.0
57
+ */
58
+ export declare class DataSaveControl extends DropdownListControl {
59
+ static className: string;
60
+ static classNames: Array<string>;
61
+ _settings: IDataSaveControlSettings;
62
+ _privateSettings: IDataSaveControlPrivate;
63
+ _events: IDataSaveControlEvents;
64
+ protected _afterNew(): void;
65
+ _beforeChanged(): void;
66
+ saveData(): void;
67
+ restoreData(): void;
68
+ clearData(): void;
69
+ protected _getDefaultIcon(): SVGElement;
70
+ protected _populateInputs(): void;
71
+ protected _getStorageId(bucket: string): string;
72
+ protected _getDrawingControl(): DrawingControl;
73
+ protected _getIndicatorControl(): IndicatorControl;
74
+ }
75
+ //# sourceMappingURL=DataSaveControl.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataSaveControl.d.ts","sourceRoot":"","sources":["../../../../../../src/.internal/charts/stock/toolbar/DataSaveControl.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAExD,OAAO,EAAE,mBAAmB,EAAE,4BAA4B,EAAE,2BAA2B,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AACnJ,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAKtD,MAAM,WAAW,oBAAqB,SAAQ,iBAAiB;CAC9D;AAED,MAAM,WAAW,wBAAyB,SAAQ,4BAA4B;IAC7E;;;;;OAKG;IACH,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB;;;;;;OAMG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,uBAAwB,SAAQ,2BAA2B;IAC3E,cAAc,CAAC,EAAE,cAAc,CAAC;IAChC,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;IACpC,SAAS,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,sBAAuB,SAAQ,0BAA0B;IAEzE;;;OAGG;IACH,KAAK,EAAE;QACN,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;KACnB,CAAC;IAEF;;;OAGG;IACH,QAAQ,EAAE;QACT,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;KACnB,CAAC;IAEF;;OAEG;IACH,OAAO,EAAE,EAAE,CAAC;CAEZ;AAED;;;;;;GAMG;AACH,qBAAa,eAAgB,SAAQ,mBAAmB;IACvD,OAAc,SAAS,EAAE,MAAM,CAAqB;IACpD,OAAc,UAAU,EAAE,KAAK,CAAC,MAAM,CAAC,CAAsE;IAE9F,SAAS,EAAE,wBAAwB,CAAC;IACpC,gBAAgB,EAAE,uBAAuB,CAAC;IAC1C,OAAO,EAAE,sBAAsB,CAAC;IAE/C,SAAS,CAAC,SAAS;IAsDZ,cAAc;IAiBd,QAAQ,IAAI,IAAI;IA2BhB,WAAW,IAAI,IAAI;IA2BnB,SAAS,IAAI,IAAI;IAWxB,SAAS,CAAC,eAAe,IAAI,UAAU;IAIvC,SAAS,CAAC,eAAe,IAAI,IAAI;IAyBjC,SAAS,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAI/C,SAAS,CAAC,kBAAkB,IAAI,cAAc;IAkB9C,SAAS,CAAC,oBAAoB,IAAI,gBAAgB;CAkBlD"}