import React, { Component } from "react"; import * as am5 from "@amcharts/amcharts5"; import * as am5percent from "@amcharts/amcharts5/percent"; import am5themes_Animated from "@amcharts/amcharts5/themes/Animated"; import CommonUtil from "../../../resources/js/CommonUtil"; export default function Chart5({ data }) { const createChart = () => { console.log('createChart data : ', data); let root = am5.Root.new("Chart5"); root._logo.dispose(); // 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/percent-charts/sliced-chart/ let chart = root.container.children.push(am5percent.SlicedChart.new(root, { layout: root.verticalLayout })); // Create series // https://www.amcharts.com/docs/v5/charts/percent-charts/sliced-chart/#Series let series = chart.series.push(am5percent.PictorialStackedSeries.new(root, { alignLabels: true, orientation: "vertical", valueField: "count", categoryField: "agency_name", svgPath: "M53.5,476c0,14,6.833,21,20.5,21s20.5-7,20.5-21V287h21v189c0,14,6.834,21,20.5,21 c13.667,0,20.5-7,20.5-21V154h10v116c0,7.334,2.5,12.667,7.5,16s10.167,3.333,15.5,0s8-8.667,8-16V145c0-13.334-4.5-23.667-13.5-31 s-21.5-11-37.5-11h-82c-15.333,0-27.833,3.333-37.5,10s-14.5,17-14.5,31v133c0,6,2.667,10.333,8,13s10.5,2.667,15.5,0s7.5-7,7.5-13 V154h10V476 M61.5,42.5c0,11.667,4.167,21.667,12.5,30S92.333,85,104,85s21.667-4.167,30-12.5S146.5,54,146.5,42 c0-11.335-4.167-21.168-12.5-29.5C125.667,4.167,115.667,0,104,0S82.333,4.167,74,12.5S61.5,30.833,61.5,42.5z" })); series.labelsContainer.set("width", 100); series.ticks.template.set("location", 0.6); // Set data // https://www.amcharts.com/docs/v5/charts/percent-charts/sliced-chart/#Setting_data /*series.data.setAll([ { value: 10, category: "A복지관" }, { value: 9, category: "B복지관" }, { value: 6, category: "C복지관" }, { value: 5, category: "D복지관" }, { value: 4, category: "E복지관" }, ]);*/ series.data.setAll(data); // Play initial series animation // https://www.amcharts.com/docs/v5/concepts/animations/#Animation_of_series chart.appear(1000, 100); // end am5.ready() } React.useEffect(() => { console.log('React.useEffect data : ', data); if (CommonUtil.isEmpty(data) == false) { createChart(); } }, [data]) return (
) }