import * as am5 from "@amcharts/amcharts5"; import * as am5xy from "@amcharts/amcharts5/xy"; import am5themes_Animated from "@amcharts/amcharts5/themes/Animated"; // Create root element // https://www.amcharts.com/docs/v5/getting-started/#Root_element var root = am5.Root.new("chartdiv"); // Set themes // https://www.amcharts.com/docs/v5/concepts/themes/ root.setThemes([ am5themes_Animated.new(root) ]); // Create chart // https://www.amcharts.com/docs/v5/charts/xy-chart/ var chart = root.container.children.push(am5xy.XYChart.new(root, { panX: true, panY: true, wheelX: "panX", wheelY: "zoomX" })); chart.get("colors").set("step", 3); // Add cursor // https://www.amcharts.com/docs/v5/charts/xy-chart/cursor/ var cursor = chart.set("cursor", am5xy.XYCursor.new(root, {})); cursor.lineY.set("visible", false); // Create axes // https://www.amcharts.com/docs/v5/charts/xy-chart/axes/ var xRenderer = am5xy.AxisRendererX.new(root, { minGridDistance: 30, minorGridEnabled: true }); xRenderer.labels.template.setAll({ rotation: -90, centerY: am5.p50, centerX: 0 }); var xAxis = chart.xAxes.push(am5xy.CategoryAxis.new(root, { maxDeviation: 0.3, categoryField: "category", renderer: xRenderer, tooltip: am5.Tooltip.new(root, {}) })); var yAxis = chart.yAxes.push(am5xy.ValueAxis.new(root, { maxDeviation: 0.3, renderer: am5xy.AxisRendererY.new(root, {}) })); // Create series // https://www.amcharts.com/docs/v5/charts/xy-chart/series/ var series = chart.series.push(am5xy.ColumnSeries.new(root, { name: "Series 1", xAxis: xAxis, yAxis: yAxis, valueYField: "close", openValueYField: "open", categoryXField: "category", tooltip: am5.Tooltip.new(root, { labelText: "{openValueY} - {valueY}" }) })); series.columns.template.setAll({ width: 0.5 }); series.bullets.push(function() { return am5.Bullet.new(root, { locationY: 0, sprite: am5.Circle.new(root, { radius: 5, fill: series.get("fill") }) }) }) var nextColor = chart.get("colors").getIndex(1); series.bullets.push(function() { return am5.Bullet.new(root, { locationY: 1, sprite: am5.Circle.new(root, { radius: 5, fill: nextColor }) }) }) // Set data var data = []; var open = 100; var close = 120; var names = ["Raina", "Demarcus", "Carlo", "Jacinda", "Richie", "Antony", "Amada", "Idalia", "Janella", "Marla", "Curtis", "Shellie", "Meggan", "Nathanael", "Jannette", "Tyrell", "Sheena", "Maranda", "Briana", "Rosa", "Rosanne", "Herman", "Wayne", "Shamika", "Suk", "Clair", "Olivia", "Hans", "Glennie", ]; for (var i = 0; i < names.length; i++) { open += Math.round((Math.random() < 0.5 ? 1 : -1) * Math.random() * 5); close = open + Math.round(Math.random() * 10) + 3; data.push({ category: names[i], open: open, close: close }); } xAxis.data.setAll(data); series.data.setAll(data); // Make stuff animate on load // https://www.amcharts.com/docs/v5/concepts/animations/ series.appear(1000); chart.appear(1000, 100);