@amcharts/amcharts5 5.11.2 → 5.12.0

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 (283) hide show
  1. package/.internal/charts/radar/RadarChart.d.ts +1 -0
  2. package/.internal/charts/radar/RadarChart.d.ts.map +1 -1
  3. package/.internal/charts/radar/RadarChart.js +4 -0
  4. package/.internal/charts/radar/RadarChart.js.map +1 -1
  5. package/.internal/charts/stock/SettingsModal.d.ts +1 -0
  6. package/.internal/charts/stock/SettingsModal.d.ts.map +1 -1
  7. package/.internal/charts/stock/SettingsModal.js +11 -3
  8. package/.internal/charts/stock/SettingsModal.js.map +1 -1
  9. package/.internal/charts/stock/indicators/Indicator.d.ts +1 -1
  10. package/.internal/charts/stock/indicators/Indicator.d.ts.map +1 -1
  11. package/.internal/charts/stock/indicators/Indicator.js.map +1 -1
  12. package/.internal/charts/stock/toolbar/DrawingControl.d.ts.map +1 -1
  13. package/.internal/charts/stock/toolbar/DrawingControl.js +6 -3
  14. package/.internal/charts/stock/toolbar/DrawingControl.js.map +1 -1
  15. package/.internal/charts/timeline/AxisRendererCurveX.d.ts +132 -0
  16. package/.internal/charts/timeline/AxisRendererCurveX.d.ts.map +1 -0
  17. package/.internal/charts/timeline/AxisRendererCurveX.js +537 -0
  18. package/.internal/charts/timeline/AxisRendererCurveX.js.map +1 -0
  19. package/.internal/charts/timeline/AxisRendererCurveY.d.ts +132 -0
  20. package/.internal/charts/timeline/AxisRendererCurveY.d.ts.map +1 -0
  21. package/.internal/charts/timeline/AxisRendererCurveY.js +308 -0
  22. package/.internal/charts/timeline/AxisRendererCurveY.js.map +1 -0
  23. package/.internal/charts/timeline/CurveChart.d.ts +63 -0
  24. package/.internal/charts/timeline/CurveChart.d.ts.map +1 -0
  25. package/.internal/charts/timeline/CurveChart.js +123 -0
  26. package/.internal/charts/timeline/CurveChart.js.map +1 -0
  27. package/.internal/charts/timeline/CurveColumnSeries.d.ts +66 -0
  28. package/.internal/charts/timeline/CurveColumnSeries.d.ts.map +1 -0
  29. package/.internal/charts/timeline/CurveColumnSeries.js +163 -0
  30. package/.internal/charts/timeline/CurveColumnSeries.js.map +1 -0
  31. package/.internal/charts/timeline/CurveCursor.d.ts +61 -0
  32. package/.internal/charts/timeline/CurveCursor.d.ts.map +1 -0
  33. package/.internal/charts/timeline/CurveCursor.js +134 -0
  34. package/.internal/charts/timeline/CurveCursor.js.map +1 -0
  35. package/.internal/charts/timeline/CurveDefaultTheme.d.ts +8 -0
  36. package/.internal/charts/timeline/CurveDefaultTheme.d.ts.map +1 -0
  37. package/.internal/charts/timeline/CurveDefaultTheme.js +72 -0
  38. package/.internal/charts/timeline/CurveDefaultTheme.js.map +1 -0
  39. package/.internal/charts/timeline/CurveLineSeries.d.ts +40 -0
  40. package/.internal/charts/timeline/CurveLineSeries.d.ts.map +1 -0
  41. package/.internal/charts/timeline/CurveLineSeries.js +101 -0
  42. package/.internal/charts/timeline/CurveLineSeries.js.map +1 -0
  43. package/.internal/charts/timeline/SerpentineChart.d.ts +60 -0
  44. package/.internal/charts/timeline/SerpentineChart.d.ts.map +1 -0
  45. package/.internal/charts/timeline/SerpentineChart.js +146 -0
  46. package/.internal/charts/timeline/SerpentineChart.js.map +1 -0
  47. package/.internal/charts/timeline/SpiralChart.d.ts +60 -0
  48. package/.internal/charts/timeline/SpiralChart.d.ts.map +1 -0
  49. package/.internal/charts/timeline/SpiralChart.js +58 -0
  50. package/.internal/charts/timeline/SpiralChart.js.map +1 -0
  51. package/.internal/charts/xy/axes/DateAxis.d.ts.map +1 -1
  52. package/.internal/charts/xy/axes/DateAxis.js +1 -0
  53. package/.internal/charts/xy/axes/DateAxis.js.map +1 -1
  54. package/.internal/charts/xy/series/BaseColumnSeries.d.ts.map +1 -1
  55. package/.internal/charts/xy/series/BaseColumnSeries.js +3 -1
  56. package/.internal/charts/xy/series/BaseColumnSeries.js.map +1 -1
  57. package/.internal/core/Classes.d.ts +16 -0
  58. package/.internal/core/Classes.d.ts.map +1 -1
  59. package/.internal/core/Classes.js.map +1 -1
  60. package/.internal/core/Registry.js +1 -1
  61. package/.internal/core/Registry.js.map +1 -1
  62. package/.internal/core/render/SerialChart.d.ts.map +1 -1
  63. package/.internal/core/render/SerialChart.js +12 -0
  64. package/.internal/core/render/SerialChart.js.map +1 -1
  65. package/.internal/core/render/Sprite.d.ts +7 -0
  66. package/.internal/core/render/Sprite.d.ts.map +1 -1
  67. package/.internal/core/render/Sprite.js +10 -0
  68. package/.internal/core/render/Sprite.js.map +1 -1
  69. package/.internal/core/util/List.d.ts +12 -0
  70. package/.internal/core/util/List.d.ts.map +1 -1
  71. package/.internal/core/util/List.js +23 -2
  72. package/.internal/core/util/List.js.map +1 -1
  73. package/.internal/core/util/Math.d.ts.map +1 -1
  74. package/.internal/core/util/Math.js +12 -5
  75. package/.internal/core/util/Math.js.map +1 -1
  76. package/.internal/plugins/json/Classes-script.d.ts +16 -0
  77. package/.internal/plugins/json/Classes-script.d.ts.map +1 -1
  78. package/.internal/plugins/json/Classes-script.js +8 -0
  79. package/.internal/plugins/json/Classes-script.js.map +1 -1
  80. package/.internal/plugins/json/Classes.d.ts +16 -0
  81. package/.internal/plugins/json/Classes.d.ts.map +1 -1
  82. package/.internal/plugins/json/Classes.js +8 -0
  83. package/.internal/plugins/json/Classes.js.map +1 -1
  84. package/CHANGELOG.md +24 -0
  85. package/examples/javascript/flow-arc-horizontal/package.json +1 -1
  86. package/examples/javascript/flow-arc-vertical/package.json +1 -1
  87. package/examples/javascript/flow-chord/package.json +1 -1
  88. package/examples/javascript/flow-chord-directed/package.json +1 -1
  89. package/examples/javascript/flow-chord-non-ribbon/package.json +1 -1
  90. package/examples/javascript/flow-sankey/package.json +1 -1
  91. package/examples/javascript/gauge/package.json +1 -1
  92. package/examples/javascript/gauge-bands/package.json +1 -1
  93. package/examples/javascript/hierarchy-force-directed/package.json +1 -1
  94. package/examples/javascript/hierarchy-pack/package.json +1 -1
  95. package/examples/javascript/hierarchy-partition/package.json +1 -1
  96. package/examples/javascript/hierarchy-sunburst/package.json +1 -1
  97. package/examples/javascript/hierarchy-tree/package.json +1 -1
  98. package/examples/javascript/hierarchy-treemap/package.json +1 -1
  99. package/examples/javascript/hierarchy-voronoi-treemap/package.json +1 -1
  100. package/examples/javascript/jest/package.json +1 -1
  101. package/examples/javascript/json-pie/package.json +1 -1
  102. package/examples/javascript/json-xy/package.json +1 -1
  103. package/examples/javascript/map-animating-along-lines/package.json +1 -1
  104. package/examples/javascript/map-clustered-points/package.json +1 -1
  105. package/examples/javascript/map-day-and-night/package.json +1 -1
  106. package/examples/javascript/map-globe-rotate-to-country/package.json +1 -1
  107. package/examples/javascript/map-globe-with-projected-circles/package.json +1 -1
  108. package/examples/javascript/map-with-bubbles/package.json +1 -1
  109. package/examples/javascript/map-zoom-to-country/package.json +1 -1
  110. package/examples/javascript/misc-40-charts/package.json +1 -1
  111. package/examples/javascript/misc-microchart-grid/package.json +1 -1
  112. package/examples/javascript/pie-chart/package.json +1 -1
  113. package/examples/javascript/pie-donut-chart/package.json +1 -1
  114. package/examples/javascript/pie-variable-radius/package.json +1 -1
  115. package/examples/javascript/radar-column-iwatch-style/package.json +1 -1
  116. package/examples/javascript/radar-heat-map/package.json +1 -1
  117. package/examples/javascript/radar-line/package.json +1 -1
  118. package/examples/javascript/radar-time-line/package.json +1 -1
  119. package/examples/javascript/sliced-funnel/package.json +1 -1
  120. package/examples/javascript/sliced-pictorial-stacked/package.json +1 -1
  121. package/examples/javascript/sliced-pyramid/package.json +1 -1
  122. package/examples/javascript/stock-chart/package.json +1 -1
  123. package/examples/javascript/stock-chart-comparing-stocks/package.json +1 -1
  124. package/examples/javascript/stock-chart-data-granularity/package.json +1 -1
  125. package/examples/javascript/stock-chart-data-grouping/package.json +1 -1
  126. package/examples/javascript/stock-chart-intraday/package.json +1 -1
  127. package/examples/javascript/stock-chart-live/package.json +1 -1
  128. package/examples/javascript/stock-chart-volume-separate-panel/package.json +1 -1
  129. package/examples/javascript/timeline-horizontal-serpentine-chart/README.md +6 -0
  130. package/examples/javascript/timeline-horizontal-serpentine-chart/index.css +11 -0
  131. package/examples/javascript/timeline-horizontal-serpentine-chart/index.html +12 -0
  132. package/examples/javascript/timeline-horizontal-serpentine-chart/index.js +268 -0
  133. package/examples/javascript/timeline-horizontal-serpentine-chart/package.json +16 -0
  134. package/examples/javascript/timeline-horizontal-serpentine-chart/webpack.config.js +38 -0
  135. package/examples/javascript/timeline-linear-process-diagram/README.md +6 -0
  136. package/examples/javascript/timeline-linear-process-diagram/index.css +11 -0
  137. package/examples/javascript/timeline-linear-process-diagram/index.html +12 -0
  138. package/examples/javascript/timeline-linear-process-diagram/index.js +365 -0
  139. package/examples/javascript/timeline-linear-process-diagram/package.json +16 -0
  140. package/examples/javascript/timeline-linear-process-diagram/webpack.config.js +38 -0
  141. package/examples/javascript/timeline-serpentine-chart/README.md +6 -0
  142. package/examples/javascript/timeline-serpentine-chart/index.css +11 -0
  143. package/examples/javascript/timeline-serpentine-chart/index.html +12 -0
  144. package/examples/javascript/timeline-serpentine-chart/index.js +274 -0
  145. package/examples/javascript/timeline-serpentine-chart/package.json +16 -0
  146. package/examples/javascript/timeline-serpentine-chart/webpack.config.js +38 -0
  147. package/examples/javascript/timeline-spiral-chart/README.md +6 -0
  148. package/examples/javascript/timeline-spiral-chart/index.css +11 -0
  149. package/examples/javascript/timeline-spiral-chart/index.html +12 -0
  150. package/examples/javascript/timeline-spiral-chart/index.js +274 -0
  151. package/examples/javascript/timeline-spiral-chart/package.json +16 -0
  152. package/examples/javascript/timeline-spiral-chart/webpack.config.js +38 -0
  153. package/examples/javascript/venn-diagram/package.json +1 -1
  154. package/examples/javascript/wordcloud-with-data/package.json +1 -1
  155. package/examples/javascript/wordcloud-with-text/package.json +1 -1
  156. package/examples/javascript/xy-100-percent-stacked-column/package.json +1 -1
  157. package/examples/javascript/xy-animated-bullet-at-the-end-of-the-series/package.json +1 -1
  158. package/examples/javascript/xy-bubble/package.json +1 -1
  159. package/examples/javascript/xy-candlestick/package.json +1 -1
  160. package/examples/javascript/xy-clustered-column/package.json +1 -1
  161. package/examples/javascript/xy-column/package.json +1 -1
  162. package/examples/javascript/xy-comparing-series-google-analytics-style/package.json +1 -1
  163. package/examples/javascript/xy-data-grouping/package.json +1 -1
  164. package/examples/javascript/xy-draggable-range/package.json +1 -1
  165. package/examples/javascript/xy-drawing-series-with-mouse-or-touch/package.json +1 -1
  166. package/examples/javascript/xy-dumbbell plot/package.json +1 -1
  167. package/examples/javascript/xy-evenly-spaced-date-axis/package.json +1 -1
  168. package/examples/javascript/xy-line/package.json +1 -1
  169. package/examples/javascript/xy-line-highlight-on-legend-hover/package.json +1 -1
  170. package/examples/javascript/xy-live-data/package.json +1 -1
  171. package/examples/javascript/xy-multiple-synced-value-axes/package.json +1 -1
  172. package/examples/javascript/xy-ohlc/package.json +1 -1
  173. package/examples/javascript/xy-real-time-data-sorting/package.json +1 -1
  174. package/examples/javascript/xy-smoothed-line/package.json +1 -1
  175. package/examples/javascript/xy-stacked-and-clustered-column/package.json +1 -1
  176. package/examples/javascript/xy-stacked-column/package.json +1 -1
  177. package/examples/javascript/xy-stacked-step/package.json +1 -1
  178. package/examples/javascript/xy-stock/package.json +1 -1
  179. package/examples/javascript/xy-stock-comparing/package.json +1 -1
  180. package/examples/typescript/flow-arc-horizontal/package.json +1 -1
  181. package/examples/typescript/flow-arc-vertical/package.json +1 -1
  182. package/examples/typescript/flow-chord/package.json +1 -1
  183. package/examples/typescript/flow-chord-directed/package.json +1 -1
  184. package/examples/typescript/flow-chord-non-ribbon/package.json +1 -1
  185. package/examples/typescript/flow-sankey/package.json +1 -1
  186. package/examples/typescript/gauge/package.json +1 -1
  187. package/examples/typescript/gauge-bands/package.json +1 -1
  188. package/examples/typescript/hierarchy-force-directed/package.json +1 -1
  189. package/examples/typescript/hierarchy-pack/package.json +1 -1
  190. package/examples/typescript/hierarchy-partition/package.json +1 -1
  191. package/examples/typescript/hierarchy-sunburst/package.json +1 -1
  192. package/examples/typescript/hierarchy-tree/package.json +1 -1
  193. package/examples/typescript/hierarchy-treemap/package.json +1 -1
  194. package/examples/typescript/hierarchy-voronoi-treemap/package.json +1 -1
  195. package/examples/typescript/jest/package.json +1 -1
  196. package/examples/typescript/json-pie/package.json +1 -1
  197. package/examples/typescript/json-xy/package.json +1 -1
  198. package/examples/typescript/map-animating-along-lines/package.json +1 -1
  199. package/examples/typescript/map-clustered-points/package.json +1 -1
  200. package/examples/typescript/map-day-and-night/package.json +1 -1
  201. package/examples/typescript/map-globe-rotate-to-country/package.json +1 -1
  202. package/examples/typescript/map-globe-with-projected-circles/package.json +1 -1
  203. package/examples/typescript/map-with-bubbles/package.json +1 -1
  204. package/examples/typescript/map-zoom-to-country/package.json +1 -1
  205. package/examples/typescript/misc-40-charts/package.json +1 -1
  206. package/examples/typescript/misc-microchart-grid/package.json +1 -1
  207. package/examples/typescript/pie-chart/package.json +1 -1
  208. package/examples/typescript/pie-donut-chart/package.json +1 -1
  209. package/examples/typescript/pie-variable-radius/package.json +1 -1
  210. package/examples/typescript/radar-column-iwatch-style/package.json +1 -1
  211. package/examples/typescript/radar-heat-map/package.json +1 -1
  212. package/examples/typescript/radar-line/package.json +1 -1
  213. package/examples/typescript/radar-time-line/package.json +1 -1
  214. package/examples/typescript/sliced-funnel/package.json +1 -1
  215. package/examples/typescript/sliced-pictorial-stacked/package.json +1 -1
  216. package/examples/typescript/sliced-pyramid/package.json +1 -1
  217. package/examples/typescript/stock-chart/package.json +1 -1
  218. package/examples/typescript/stock-chart-comparing-stocks/package.json +1 -1
  219. package/examples/typescript/stock-chart-data-granularity/package.json +1 -1
  220. package/examples/typescript/stock-chart-data-grouping/package.json +1 -1
  221. package/examples/typescript/stock-chart-intraday/package.json +1 -1
  222. package/examples/typescript/stock-chart-live/package.json +1 -1
  223. package/examples/typescript/stock-chart-volume-separate-panel/package.json +1 -1
  224. package/examples/typescript/timeline-horizontal-serpentine-chart/README.md +6 -0
  225. package/examples/typescript/timeline-horizontal-serpentine-chart/index.css +11 -0
  226. package/examples/typescript/timeline-horizontal-serpentine-chart/index.html +12 -0
  227. package/examples/typescript/timeline-horizontal-serpentine-chart/index.ts +268 -0
  228. package/examples/typescript/timeline-horizontal-serpentine-chart/package.json +18 -0
  229. package/examples/typescript/timeline-horizontal-serpentine-chart/tsconfig.json +12 -0
  230. package/examples/typescript/timeline-horizontal-serpentine-chart/webpack.config.js +45 -0
  231. package/examples/typescript/timeline-linear-process-diagram/README.md +6 -0
  232. package/examples/typescript/timeline-linear-process-diagram/index.css +11 -0
  233. package/examples/typescript/timeline-linear-process-diagram/index.html +12 -0
  234. package/examples/typescript/timeline-linear-process-diagram/index.ts +365 -0
  235. package/examples/typescript/timeline-linear-process-diagram/package.json +18 -0
  236. package/examples/typescript/timeline-linear-process-diagram/tsconfig.json +12 -0
  237. package/examples/typescript/timeline-linear-process-diagram/webpack.config.js +45 -0
  238. package/examples/typescript/timeline-serpentine-chart/README.md +6 -0
  239. package/examples/typescript/timeline-serpentine-chart/index.css +11 -0
  240. package/examples/typescript/timeline-serpentine-chart/index.html +12 -0
  241. package/examples/typescript/timeline-serpentine-chart/index.ts +274 -0
  242. package/examples/typescript/timeline-serpentine-chart/package.json +18 -0
  243. package/examples/typescript/timeline-serpentine-chart/tsconfig.json +12 -0
  244. package/examples/typescript/timeline-serpentine-chart/webpack.config.js +45 -0
  245. package/examples/typescript/timeline-spiral-chart/README.md +6 -0
  246. package/examples/typescript/timeline-spiral-chart/index.css +11 -0
  247. package/examples/typescript/timeline-spiral-chart/index.html +12 -0
  248. package/examples/typescript/timeline-spiral-chart/index.ts +274 -0
  249. package/examples/typescript/timeline-spiral-chart/package.json +18 -0
  250. package/examples/typescript/timeline-spiral-chart/tsconfig.json +12 -0
  251. package/examples/typescript/timeline-spiral-chart/webpack.config.js +45 -0
  252. package/examples/typescript/venn-diagram/package.json +1 -1
  253. package/examples/typescript/wordcloud-with-data/package.json +1 -1
  254. package/examples/typescript/wordcloud-with-text/package.json +1 -1
  255. package/examples/typescript/xy-100-percent-stacked-column/package.json +1 -1
  256. package/examples/typescript/xy-animated-bullet-at-the-end-of-the-series/package.json +1 -1
  257. package/examples/typescript/xy-bubble/package.json +1 -1
  258. package/examples/typescript/xy-candlestick/package.json +1 -1
  259. package/examples/typescript/xy-clustered-column/package.json +1 -1
  260. package/examples/typescript/xy-column/package.json +1 -1
  261. package/examples/typescript/xy-comparing-series-google-analytics-style/package.json +1 -1
  262. package/examples/typescript/xy-data-grouping/package.json +1 -1
  263. package/examples/typescript/xy-draggable-range/package.json +1 -1
  264. package/examples/typescript/xy-drawing-series-with-mouse-or-touch/package.json +1 -1
  265. package/examples/typescript/xy-dumbbell plot/package.json +1 -1
  266. package/examples/typescript/xy-evenly-spaced-date-axis/package.json +1 -1
  267. package/examples/typescript/xy-line/package.json +1 -1
  268. package/examples/typescript/xy-line-highlight-on-legend-hover/package.json +1 -1
  269. package/examples/typescript/xy-live-data/package.json +1 -1
  270. package/examples/typescript/xy-multiple-synced-value-axes/package.json +1 -1
  271. package/examples/typescript/xy-ohlc/package.json +1 -1
  272. package/examples/typescript/xy-real-time-data-sorting/package.json +1 -1
  273. package/examples/typescript/xy-smoothed-line/package.json +1 -1
  274. package/examples/typescript/xy-stacked-and-clustered-column/package.json +1 -1
  275. package/examples/typescript/xy-stacked-column/package.json +1 -1
  276. package/examples/typescript/xy-stacked-step/package.json +1 -1
  277. package/examples/typescript/xy-stock/package.json +1 -1
  278. package/examples/typescript/xy-stock-comparing/package.json +1 -1
  279. package/package.json +1 -1
  280. package/timeline.d.ts +11 -0
  281. package/timeline.d.ts.map +1 -0
  282. package/timeline.js +11 -0
  283. package/timeline.js.map +1 -0
@@ -0,0 +1,274 @@
1
+ import * as am5 from "@amcharts/amcharts5";
2
+ import * as am5xy from "@amcharts/amcharts5/xy";
3
+ import * as am5timeline from "@amcharts/amcharts5/timeline";
4
+ import am5themes_Animated from "@amcharts/amcharts5/themes/Animated";
5
+
6
+ const root = am5.Root.new("chartdiv");
7
+
8
+ // Set themes
9
+ // https://www.amcharts.com/docs/v5/concepts/themes/
10
+ root.setThemes([
11
+ am5themes_Animated.new(root)
12
+ ]);
13
+
14
+
15
+ // Create chart
16
+ const chart = root.container.children.push(am5timeline.SerpentineChart.new(root, {
17
+ bendCount: 3,
18
+ startLocation: 0.2,
19
+ endLocation: 1,
20
+ wheelY: "zoomX"
21
+ }));
22
+
23
+ chart.set("scrollbarX", am5.Scrollbar.new(root, {
24
+ orientation: "horizontal"
25
+ }));
26
+
27
+ const yRenderer = am5timeline.AxisRendererCurveY.new(root, {});
28
+
29
+ yRenderer.labels.template.setAll({
30
+ centerY: am5.p50,
31
+ centerX: am5.p100,
32
+ fontSize: 11
33
+ });
34
+
35
+ yRenderer.grid.template.set("forceHidden", true);
36
+
37
+ // Create axes and their renderers
38
+ const xRenderer = am5timeline.AxisRendererCurveX.new(root, {
39
+ yRenderer: yRenderer,
40
+ strokeDasharray: [2, 3],
41
+ strokeOpacity: 0.5,
42
+ stroke: am5.color(0x000000)
43
+ });
44
+
45
+ xRenderer.labels.template.setAll({
46
+ centerY: am5.p50,
47
+ fontSize: 11,
48
+ minPosition: 0.01
49
+ });
50
+
51
+ xRenderer.labels.template.setup = function(target) {
52
+ target.set("layer", 30);
53
+ target.set("background", am5.Rectangle.new(root, {
54
+ fill: am5.color(0xffffff),
55
+ fillOpacity: 1
56
+ }));
57
+ }
58
+
59
+ const yAxis = chart.yAxes.push(am5xy.CategoryAxis.new(root, {
60
+ maxDeviation: 0,
61
+ categoryField: "category",
62
+ renderer: yRenderer
63
+ }));
64
+
65
+ const xAxis = chart.xAxes.push(am5xy.DateAxis.new(root, {
66
+ baseInterval: { timeUnit: "day", count: 1 },
67
+ renderer: xRenderer,
68
+ tooltip: am5.Tooltip.new(root, {})
69
+ }));
70
+
71
+ // Data
72
+ const colorSet = chart.get("colors");
73
+
74
+ const data = [{
75
+ "category": "Module #1",
76
+ "start": new Date("2019-01-10").getTime(),
77
+ "end": new Date("2019-01-13").getTime(),
78
+ "color": colorSet.getIndex(0),
79
+ "task": "Gathering requirements"
80
+ }, {
81
+ "category": "Module #1",
82
+ "start": new Date("2019-02-05").getTime(),
83
+ "end": new Date("2019-04-18").getTime(),
84
+ "color": colorSet.getIndex(0),
85
+ "task": "Development"
86
+ }, {
87
+ "category": "Module #2",
88
+ "start": new Date("2019-01-08").getTime(),
89
+ "end": new Date("2019-01-10").getTime(),
90
+ "color": colorSet.getIndex(5),
91
+ "task": "Gathering requirements"
92
+ }, {
93
+ "category": "Module #2",
94
+ "start": new Date("2019-01-12").getTime(),
95
+ "end": new Date("2019-01-15").getTime(),
96
+ "color": colorSet.getIndex(5),
97
+ "task": "Producing specifications"
98
+ }, {
99
+ "category": "Module #2",
100
+ "start": new Date("2019-01-16").getTime(),
101
+ "end": new Date("2019-02-05").getTime(),
102
+ "color": colorSet.getIndex(5),
103
+ "task": "Development"
104
+ }, {
105
+ "category": "Module #2",
106
+ "start": new Date("2019-02-10").getTime(),
107
+ "end": new Date("2019-02-18").getTime(),
108
+ "color": colorSet.getIndex(5),
109
+ "task": "Testing and QA"
110
+ }, {
111
+ "category": ""
112
+ }, {
113
+ "category": "Module #3",
114
+ "start": new Date("2019-01-01").getTime(),
115
+ "end": new Date("2019-01-19").getTime(),
116
+ "color": colorSet.getIndex(9),
117
+ "task": "Gathering requirements"
118
+ }, {
119
+ "category": "Module #3",
120
+ "start": new Date("2019-02-01").getTime(),
121
+ "end": new Date("2019-02-10").getTime(),
122
+ "color": colorSet.getIndex(9),
123
+ "task": "Producing specifications"
124
+ }, {
125
+ "category": "Module #3",
126
+ "start": new Date("2019-03-10").getTime(),
127
+ "end": new Date("2019-04-15").getTime(),
128
+ "color": colorSet.getIndex(9),
129
+ "task": "Development"
130
+ }, {
131
+ "category": "Module #3",
132
+ "start": new Date("2019-04-20").getTime(),
133
+ "end": new Date("2019-04-30").getTime(),
134
+ "color": colorSet.getIndex(9),
135
+ "task": "Testing and QA",
136
+ "disabled2": false,
137
+ "image2": "/wp-content/uploads/assets/timeline/rachel.jpg",
138
+ "location": 0
139
+ }, {
140
+ "category": "Module #4",
141
+ "start": new Date("2019-01-15").getTime(),
142
+ "end": new Date("2019-02-12").getTime(),
143
+ "color": colorSet.getIndex(15),
144
+ "task": "Gathering requirements",
145
+ "disabled1": false,
146
+ "image1": "/wp-content/uploads/assets/timeline/monica.jpg"
147
+ }, {
148
+ "category": "Module #4",
149
+ "start": new Date("2019-02-25").getTime(),
150
+ "end": new Date("2019-03-10").getTime(),
151
+ "color": colorSet.getIndex(15),
152
+ "task": "Development"
153
+ }, {
154
+ "category": "Module #4",
155
+ "start": new Date("2019-03-23").getTime(),
156
+ "end": new Date("2019-04-29").getTime(),
157
+ "color": colorSet.getIndex(15),
158
+ "task": "Testing and QA"
159
+ }];
160
+
161
+
162
+ // Add series
163
+ // https://www.amcharts.com/docs/v5/charts/xy-chart/series/
164
+ const series = chart.series.push(am5timeline.CurveColumnSeries.new(root, {
165
+ xAxis: xAxis,
166
+ yAxis: yAxis,
167
+ baseAxis: yAxis,
168
+ valueXField: "end",
169
+ openValueXField: "start",
170
+ categoryYField: "category",
171
+ layer: 30
172
+ }));
173
+
174
+ series.columns.template.setAll({
175
+ height: am5.percent(10),
176
+ strokeOpacity: 0
177
+ })
178
+
179
+ series.bullets.push(function(root, series, dataItem) {
180
+ const circle = am5.Circle.new(root, {
181
+ radius: 4,
182
+ fill: chart.get("colors").getIndex(series.dataItems.indexOf(dataItem)),
183
+ strokeWidth: 2,
184
+ strokeOpacity: 0.5,
185
+ layer: 30
186
+ });
187
+
188
+ return am5.Bullet.new(root, {
189
+ sprite: circle,
190
+ locationX: 0,
191
+ locationY: 0.5
192
+ })
193
+ })
194
+
195
+ series.bullets.push(function(root, series, dataItem) {
196
+ const circle = am5.Circle.new(root, {
197
+ radius: 4,
198
+ fill: chart.get("colors").getIndex(series.dataItems.indexOf(dataItem)),
199
+ strokeWidth: 2,
200
+ strokeOpacity: 0.5,
201
+ layer: 30
202
+ });
203
+
204
+ return am5.Bullet.new(root, {
205
+ sprite: circle, locationX: 1
206
+ })
207
+ })
208
+
209
+ series.columns.template.adapters.add("fill", function(fill, target) {
210
+ return chart.get("colors").getIndex(series.dataItems.indexOf(target.dataItem));
211
+ })
212
+
213
+ // line series for flags
214
+ const lineSeries = chart.series.push(am5timeline.CurveLineSeries.new(root, {
215
+ xAxis: xAxis, yAxis: yAxis, categoryYField: "category", valueXField: "date"
216
+ }));
217
+
218
+ lineSeries.strokes.template.set("forceHidden", true);
219
+
220
+ lineSeries.bullets.push(function(root, series, dataItem) {
221
+ const flag = am5.Tooltip.new(root, {
222
+ centerY: 28,
223
+ paddingBottom: 4, paddingLeft: 7, paddingRight: 7, paddingTop: 4, layer: 30
224
+ })
225
+
226
+ flag.get("background")?.setAll({
227
+ stroke: am5.color(0x000000), cornerRadius: 0
228
+ })
229
+
230
+ flag.label.setAll({
231
+ fill: am5.color(0x000000),
232
+ text: dataItem.dataContext.letter,
233
+ fontSize: "0.8em"
234
+ });
235
+
236
+ flag.show();
237
+
238
+ return am5.Bullet.new(root, {
239
+ sprite: flag,
240
+ locationX: 0.5, locationY: 0.5
241
+ })
242
+ })
243
+
244
+ lineSeries.data.setAll([
245
+ { category: "", eventDate: "2019-01-15", letter: "A", description: "Something happened here" },
246
+ { category: "", date: new Date("2019-01-23").getTime(), letter: "B", description: "Something happened here" },
247
+ { category: "", date: new Date("2019-02-10").getTime(), letter: "C", description: "Something happened here" },
248
+ { category: "", date: new Date("2019-02-29").getTime(), letter: "D", description: "Something happened here" },
249
+ { category: "", date: new Date("2019-03-06").getTime(), letter: "E", description: "Something happened here" },
250
+ { category: "", date: new Date("2019-03-12").getTime(), letter: "F", description: "Something happened here" },
251
+ { category: "", date: new Date("2019-03-22").getTime(), letter: "G", description: "Something happened here" }
252
+ ]);
253
+
254
+
255
+ const cursor = chart.set("cursor", am5timeline.CurveCursor.new(root, {
256
+ behavior: "zoomX",
257
+ xAxis: xAxis,
258
+ yAxis: yAxis
259
+ }));
260
+
261
+ series.data.setAll(data);
262
+
263
+ yAxis.data.setAll([
264
+ { category: "Module #1" },
265
+ { category: "Module #2" },
266
+ { category: "" },
267
+ { category: "Module #3" },
268
+ { category: "Module #4" }
269
+ ]);
270
+
271
+ // Animate chart and series in
272
+ // https://www.amcharts.com/docs/v5/concepts/animations/#Initial_animation
273
+ series.appear(1000);
274
+ chart.appear(1000, 100);
@@ -0,0 +1,18 @@
1
+ {
2
+ "private": true,
3
+ "name": "amcharts5-example-timeline-serpentine-chart",
4
+ "version": "0.1.0",
5
+ "devDependencies": {
6
+ "@amcharts/amcharts5": "^5.12.0",
7
+ "source-map-loader": "^4.0.1",
8
+ "ts-loader": "^9.2.2",
9
+ "typescript": "^4.3.4",
10
+ "webpack": "^5.1.3",
11
+ "webpack-cli": "^5.1.1",
12
+ "webpack-dev-server": "^4.15.0"
13
+ },
14
+ "scripts": {
15
+ "build": "webpack",
16
+ "start": "webpack serve --mode development"
17
+ }
18
+ }
@@ -0,0 +1,12 @@
1
+ {
2
+ "compilerOptions": {
3
+ "strict": true,
4
+ "esModuleInterop": true,
5
+ "sourceMap": true,
6
+ "inlineSources": true,
7
+ "moduleResolution": "node",
8
+ "module": "esnext",
9
+ "target": "es2015",
10
+ "lib": ["es6"]
11
+ }
12
+ }
@@ -0,0 +1,45 @@
1
+ var $path = require("path");
2
+
3
+ module.exports = {
4
+ mode: "production",
5
+
6
+ devtool: "source-map",
7
+
8
+ stats: "errors-warnings",
9
+
10
+ target: ["web", "es5"],
11
+
12
+ entry: {
13
+ index: "./index.ts",
14
+ },
15
+
16
+ devServer: {
17
+ publicPath: "/dist/",
18
+ liveReload: true,
19
+ overlay: true,
20
+ noInfo: true,
21
+ open: true
22
+ },
23
+
24
+ output: {
25
+ path: $path.resolve(__dirname, "dist"),
26
+ publicPath: "dist/",
27
+ filename: "[name].js",
28
+ chunkFilename: "[name].js"
29
+ },
30
+
31
+ resolve: {
32
+ extensions: [".ts", ".tsx", ".js"]
33
+ },
34
+
35
+ module: {
36
+ rules: [{
37
+ test: /.tsx?$/,
38
+ loader: "ts-loader"
39
+ }, {
40
+ test: /.js$/,
41
+ use: ["source-map-loader"],
42
+ enforce: "pre"
43
+ }]
44
+ }
45
+ };
@@ -0,0 +1,6 @@
1
+ Steps to use
2
+ ============
3
+
4
+ 1. Run `yarn`
5
+
6
+ 2. Run `yarn start` for development, or `yarn build` for production
@@ -0,0 +1,11 @@
1
+ body {
2
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
3
+ padding: 0;
4
+ margin: 0;
5
+ background-color: #ffffff;
6
+ }
7
+
8
+ #chartdiv {
9
+ width: 100%;
10
+ height: 80vh;
11
+ }
@@ -0,0 +1,12 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <title>amCharts 5 Example - timeline-spiral-chart</title>
6
+ <link rel="stylesheet" href="index.css" />
7
+ </head>
8
+ <body>
9
+ <div id="chartdiv"></div>
10
+ <script src="dist/index.js"></script>
11
+ </body>
12
+ </html>
@@ -0,0 +1,274 @@
1
+ import * as am5 from "@amcharts/amcharts5";
2
+ import * as am5xy from "@amcharts/amcharts5/xy";
3
+ import * as am5timeline from "@amcharts/amcharts5/timeline";
4
+ import am5themes_Animated from "@amcharts/amcharts5/themes/Animated";
5
+
6
+ const root = am5.Root.new("chartdiv");
7
+
8
+ // Set themes
9
+ // https://www.amcharts.com/docs/v5/concepts/themes/
10
+ root.setThemes([
11
+ am5themes_Animated.new(root)
12
+ ]);
13
+
14
+
15
+ // Create chart
16
+ const chart = root.container.children.push(am5timeline.SpiralChart.new(root, {
17
+ levelCount: 2,
18
+ wheelY: "zoomX"
19
+ }));
20
+
21
+ chart.set("scrollbarX", am5.Scrollbar.new(root, {
22
+ orientation: "horizontal"
23
+ }));
24
+
25
+ const yRenderer = am5timeline.AxisRendererCurveY.new(root, {
26
+
27
+ })
28
+
29
+ yRenderer.labels.template.setAll({
30
+ centerY: am5.p50,
31
+ centerX: am5.p100,
32
+ fontSize: 11
33
+ });
34
+
35
+ yRenderer.grid.template.set("forceHidden", true);
36
+
37
+ // Create axes and their renderers
38
+ const xRenderer = am5timeline.AxisRendererCurveX.new(root, {
39
+ yRenderer: yRenderer,
40
+ strokeDasharray: [2, 3],
41
+ strokeOpacity: 0.5,
42
+ stroke: am5.color(0x000000)
43
+ });
44
+
45
+ xRenderer.labels.template.setAll({
46
+ centerY: am5.p50,
47
+ fontSize: 11,
48
+ minPosition: 0.01
49
+ });
50
+
51
+ xRenderer.labels.template.setup = function(target) {
52
+ target.set("layer", 30);
53
+ target.set("background", am5.Rectangle.new(root, {
54
+ fill: am5.color(0xffffff),
55
+ fillOpacity: 1
56
+ }));
57
+ }
58
+
59
+ const yAxis = chart.yAxes.push(am5xy.CategoryAxis.new(root, {
60
+ maxDeviation: 0,
61
+ categoryField: "category",
62
+ renderer: yRenderer
63
+ }));
64
+
65
+ const xAxis = chart.xAxes.push(am5xy.DateAxis.new(root, {
66
+ baseInterval: { timeUnit: "day", count: 1 },
67
+ renderer: xRenderer,
68
+ tooltip: am5.Tooltip.new(root, {})
69
+ }));
70
+
71
+ // Data
72
+ const colorSet = chart.get("colors");
73
+
74
+ const data = [{
75
+ "category": "Module #1",
76
+ "start": new Date("2019-01-10").getTime(),
77
+ "end": new Date("2019-01-13").getTime(),
78
+ "color": colorSet.getIndex(0),
79
+ "task": "Gathering requirements"
80
+ }, {
81
+ "category": "Module #1",
82
+ "start": new Date("2019-02-05").getTime(),
83
+ "end": new Date("2019-04-18").getTime(),
84
+ "color": colorSet.getIndex(0),
85
+ "task": "Development"
86
+ }, {
87
+ "category": "Module #2",
88
+ "start": new Date("2019-01-08").getTime(),
89
+ "end": new Date("2019-01-10").getTime(),
90
+ "color": colorSet.getIndex(5),
91
+ "task": "Gathering requirements"
92
+ }, {
93
+ "category": "Module #2",
94
+ "start": new Date("2019-01-12").getTime(),
95
+ "end": new Date("2019-01-15").getTime(),
96
+ "color": colorSet.getIndex(5),
97
+ "task": "Producing specifications"
98
+ }, {
99
+ "category": "Module #2",
100
+ "start": new Date("2019-01-16").getTime(),
101
+ "end": new Date("2019-02-05").getTime(),
102
+ "color": colorSet.getIndex(5),
103
+ "task": "Development"
104
+ }, {
105
+ "category": "Module #2",
106
+ "start": new Date("2019-02-10").getTime(),
107
+ "end": new Date("2019-02-18").getTime(),
108
+ "color": colorSet.getIndex(5),
109
+ "task": "Testing and QA"
110
+ }, {
111
+ "category": ""
112
+ }, {
113
+ "category": "Module #3",
114
+ "start": new Date("2019-01-01").getTime(),
115
+ "end": new Date("2019-01-19").getTime(),
116
+ "color": colorSet.getIndex(9),
117
+ "task": "Gathering requirements"
118
+ }, {
119
+ "category": "Module #3",
120
+ "start": new Date("2019-02-01").getTime(),
121
+ "end": new Date("2019-02-10").getTime(),
122
+ "color": colorSet.getIndex(9),
123
+ "task": "Producing specifications"
124
+ }, {
125
+ "category": "Module #3",
126
+ "start": new Date("2019-03-10").getTime(),
127
+ "end": new Date("2019-04-15").getTime(),
128
+ "color": colorSet.getIndex(9),
129
+ "task": "Development"
130
+ }, {
131
+ "category": "Module #3",
132
+ "start": new Date("2019-04-20").getTime(),
133
+ "end": new Date("2019-04-30").getTime(),
134
+ "color": colorSet.getIndex(9),
135
+ "task": "Testing and QA",
136
+ "disabled2": false,
137
+ "image2": "/wp-content/uploads/assets/timeline/rachel.jpg",
138
+ "location": 0
139
+ }, {
140
+ "category": "Module #4",
141
+ "start": new Date("2019-01-15").getTime(),
142
+ "end": new Date("2019-02-12").getTime(),
143
+ "color": colorSet.getIndex(15),
144
+ "task": "Gathering requirements",
145
+ "disabled1": false,
146
+ "image1": "/wp-content/uploads/assets/timeline/monica.jpg"
147
+ }, {
148
+ "category": "Module #4",
149
+ "start": new Date("2019-02-25").getTime(),
150
+ "end": new Date("2019-03-10").getTime(),
151
+ "color": colorSet.getIndex(15),
152
+ "task": "Development"
153
+ }, {
154
+ "category": "Module #4",
155
+ "start": new Date("2019-03-23").getTime(),
156
+ "end": new Date("2019-04-29").getTime(),
157
+ "color": colorSet.getIndex(15),
158
+ "task": "Testing and QA"
159
+ }];
160
+
161
+
162
+ // Add series
163
+ // https://www.amcharts.com/docs/v5/charts/xy-chart/series/
164
+ const series = chart.series.push(am5timeline.CurveColumnSeries.new(root, {
165
+ xAxis: xAxis,
166
+ yAxis: yAxis,
167
+ baseAxis: yAxis,
168
+ valueXField: "end",
169
+ openValueXField: "start",
170
+ categoryYField: "category",
171
+ layer: 30
172
+ }));
173
+
174
+ series.columns.template.setAll({
175
+ height: am5.percent(10),
176
+ strokeOpacity: 0
177
+ })
178
+
179
+ series.bullets.push(function(root, series, dataItem) {
180
+ const circle = am5.Circle.new(root, {
181
+ radius: 4,
182
+ fill: chart.get("colors").getIndex(series.dataItems.indexOf(dataItem)),
183
+ strokeWidth: 2,
184
+ strokeOpacity: 0.5,
185
+ layer: 30
186
+ });
187
+
188
+ return am5.Bullet.new(root, {
189
+ sprite: circle,
190
+ locationX: 0,
191
+ locationY: 0.5
192
+ })
193
+ })
194
+
195
+ series.bullets.push(function(root, series, dataItem) {
196
+ const circle = am5.Circle.new(root, {
197
+ radius: 4,
198
+ fill: chart.get("colors").getIndex(series.dataItems.indexOf(dataItem)),
199
+ strokeWidth: 2,
200
+ strokeOpacity: 0.5,
201
+ layer: 30
202
+ });
203
+
204
+ return am5.Bullet.new(root, {
205
+ sprite: circle, locationX: 1
206
+ })
207
+ })
208
+
209
+ series.columns.template.adapters.add("fill", function(fill, target) {
210
+ return chart.get("colors").getIndex(series.dataItems.indexOf(target.dataItem));
211
+ })
212
+
213
+ // Line series for flags
214
+ const lineSeries = chart.series.push(am5timeline.CurveLineSeries.new(root, {
215
+ xAxis: xAxis, yAxis: yAxis, categoryYField: "category", valueXField: "date"
216
+ }));
217
+
218
+ lineSeries.strokes.template.set("forceHidden", true);
219
+
220
+ lineSeries.bullets.push(function(root, series, dataItem) {
221
+ const flag = am5.Tooltip.new(root, {
222
+ centerY: 28,
223
+ paddingBottom: 4, paddingLeft: 7, paddingRight: 7, paddingTop: 4, layer: 30
224
+ })
225
+
226
+ flag.get("background")?.setAll({
227
+ stroke: am5.color(0x000000), cornerRadius: 0
228
+ })
229
+
230
+ flag.label.setAll({
231
+ fill: am5.color(0x000000),
232
+ text: dataItem.dataContext.letter,
233
+ fontSize: "0.8em"
234
+ });
235
+
236
+ flag.show();
237
+
238
+ return am5.Bullet.new(root, {
239
+ sprite: flag,
240
+ locationX: 0.5, locationY: 0.5
241
+ })
242
+ });
243
+
244
+ lineSeries.data.setAll([
245
+ { category: "", eventDate: "2019-01-15", letter: "A", description: "Something happened here" },
246
+ { category: "", date: new Date("2019-01-23").getTime(), letter: "B", description: "Something happened here" },
247
+ { category: "", date: new Date("2019-02-10").getTime(), letter: "C", description: "Something happened here" },
248
+ { category: "", date: new Date("2019-02-29").getTime(), letter: "D", description: "Something happened here" },
249
+ { category: "", date: new Date("2019-03-06").getTime(), letter: "E", description: "Something happened here" },
250
+ { category: "", date: new Date("2019-03-12").getTime(), letter: "F", description: "Something happened here" },
251
+ { category: "", date: new Date("2019-03-22").getTime(), letter: "G", description: "Something happened here" }
252
+ ]);
253
+
254
+
255
+ const cursor = chart.set("cursor", am5timeline.CurveCursor.new(root, {
256
+ behavior: "zoomX",
257
+ xAxis: xAxis,
258
+ yAxis: yAxis
259
+ }));
260
+
261
+ series.data.setAll(data);
262
+
263
+ yAxis.data.setAll([
264
+ { category: "Module #1" },
265
+ { category: "Module #2" },
266
+ { category: "" },
267
+ { category: "Module #3" },
268
+ { category: "Module #4" }
269
+ ]);
270
+
271
+ // Animate chart and series in
272
+ // https://www.amcharts.com/docs/v5/concepts/animations/#Initial_animation
273
+ series.appear(1000);
274
+ chart.appear(1000, 100);
@@ -0,0 +1,18 @@
1
+ {
2
+ "private": true,
3
+ "name": "amcharts5-example-timeline-spiral-chart",
4
+ "version": "0.1.0",
5
+ "devDependencies": {
6
+ "@amcharts/amcharts5": "^5.12.0",
7
+ "source-map-loader": "^4.0.1",
8
+ "ts-loader": "^9.2.2",
9
+ "typescript": "^4.3.4",
10
+ "webpack": "^5.1.3",
11
+ "webpack-cli": "^5.1.1",
12
+ "webpack-dev-server": "^4.15.0"
13
+ },
14
+ "scripts": {
15
+ "build": "webpack",
16
+ "start": "webpack serve --mode development"
17
+ }
18
+ }
@@ -0,0 +1,12 @@
1
+ {
2
+ "compilerOptions": {
3
+ "strict": true,
4
+ "esModuleInterop": true,
5
+ "sourceMap": true,
6
+ "inlineSources": true,
7
+ "moduleResolution": "node",
8
+ "module": "esnext",
9
+ "target": "es2015",
10
+ "lib": ["es6"]
11
+ }
12
+ }