1 changed files with 82 additions and 0 deletions
@ -0,0 +1,82 @@ |
|||||||
|
import React, { useEffect, useRef, useState } from "react" |
||||||
|
import Highcharts from "highcharts" |
||||||
|
import HighchartsReact from "highcharts-react-official" |
||||||
|
import { Col, Row } from "reactstrap" |
||||||
|
import { format_angka } from "../util" |
||||||
|
import collect from "collect.js" |
||||||
|
|
||||||
|
const SPTTahunan = ({ dataSend }) => { |
||||||
|
const base_url = "<?=base_url()?>" |
||||||
|
|
||||||
|
const refChart = useRef(null) |
||||||
|
const [data, setData] = useState(null) |
||||||
|
|
||||||
|
useEffect(() => { |
||||||
|
jQuery.get({ |
||||||
|
url: base_url + "kewilayahan/kytp/sebaranSPTTahunan", |
||||||
|
dataType: "json", |
||||||
|
type: "POST", |
||||||
|
data: { |
||||||
|
...dataSend |
||||||
|
}, |
||||||
|
success: (data) => { |
||||||
|
setData(data.data) |
||||||
|
} |
||||||
|
}) |
||||||
|
}, [dataSend]) |
||||||
|
|
||||||
|
const optionsChart = (data, title) => { |
||||||
|
const total_wp = collect(data).sum("y") |
||||||
|
return { |
||||||
|
chart: { |
||||||
|
plotBackgroundColor: null, |
||||||
|
plotBorderWidth: null, |
||||||
|
plotShadow: false, |
||||||
|
type: "pie", |
||||||
|
zoomType: "xy", |
||||||
|
height: "300" |
||||||
|
}, |
||||||
|
title: { |
||||||
|
text: title, |
||||||
|
style: { fontSize: "10px" } |
||||||
|
}, |
||||||
|
tooltip: { |
||||||
|
pointFormat: "<b>{point.percentage:.1f}%</b><br>: {point.y} dari " + format_angka(total_wp) + " total NPWP yang ada" |
||||||
|
}, |
||||||
|
accessibility: { |
||||||
|
point: { |
||||||
|
valueSuffix: "%" |
||||||
|
} |
||||||
|
}, |
||||||
|
plotOptions: { |
||||||
|
pie: { |
||||||
|
allowPointSelect: true, |
||||||
|
cursor: "pointer", |
||||||
|
dataLabels: { |
||||||
|
enabled: true, |
||||||
|
style: { fontSize: "10px" }, |
||||||
|
format: "{point.name}: <br> {point.percentage:.1f} %" |
||||||
|
} |
||||||
|
} |
||||||
|
// series: pie_click
|
||||||
|
}, |
||||||
|
series: [ |
||||||
|
{ |
||||||
|
name: "", |
||||||
|
data |
||||||
|
} |
||||||
|
] |
||||||
|
} |
||||||
|
} |
||||||
|
return ( |
||||||
|
<> |
||||||
|
<Row> |
||||||
|
<Col> |
||||||
|
<HighchartsReact ref={refChart} highcharts={Highcharts} options={optionsChart(data, "SPT Tahunan")} /> |
||||||
|
</Col> |
||||||
|
</Row> |
||||||
|
</> |
||||||
|
) |
||||||
|
} |
||||||
|
|
||||||
|
export default SPTTahunan |
Loading…
Reference in new issue