You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

668 lines
20 KiB

7 months ago
import React, { useEffect, useRef, useState } from "react"
import ReactDOM from "react-dom"
7 months ago
import { Button, Card, CardBody, CardHeader, CardText, CardTitle, Col, Label, Nav, NavItem, NavLink, Row, TabContent, TabPane } from "reactstrap"
7 months ago
import Select from "react-select"
import jQuery from "jquery"
import collect from "collect.js"
import { format_angka, isObjEmpty } from "./util"
import { MultiSelect } from "react-multi-select-component"
7 months ago
import Highcharts from "highcharts"
import HighchartsReact from "highcharts-react-official"
import { Toast } from "primereact/toast"
import { Button as ButtonP } from "primereact/button"
import "primereact/resources/themes/bootstrap4-light-blue/theme.css"
import "primeflex/primeflex.css"
7 months ago
import TabProgresifitas from "./TabProgresifitas"
7 months ago
import TabPenugasan from "./TabPenugasan"
7 months ago
// import 'bootstrap/dist/css/bootstrap.m in.css';
7 months ago
// let datasend = {}
7 months ago
const Root = () => {
const base_url = "<?=base_url()?>"
const refChart1 = useRef(null)
7 months ago
const toast = useRef(null)
const [active, setActive] = useState("wilayah")
const toggle = (tab) => {
7 months ago
setActive(tab)
}
const [prop, setProp] = useState({})
const [kota, setKota] = useState({})
const [kec, setKec] = useState([])
const [kel, setKel] = useState([])
const [propSelected, setPropSelected] = useState({})
const [kotaSelected, setKotaSelected] = useState({})
const [kecSelected, setKecSelected] = useState([])
const [kelSelected, setKelSelected] = useState([])
const [kanwil, setKanwil] = useState({})
const [kpp, setKpp] = useState({})
const [seksi, setSeksi] = useState([])
const [ar, setAr] = useState([])
const [zp, setZp] = useState([])
const [kanwilSelected, setKanwilSelected] = useState({})
const [kppSelected, setKppSelected] = useState({})
const [seksiSelected, setSeksiSelected] = useState([])
const [arSelected, setArSelected] = useState([])
const [zpSelected, setZpSelected] = useState([])
7 months ago
const [dataSend, setDataSend] = useState({ opsiWilZona: null, adm4_pcode: [], id_poly_zona: [] })
7 months ago
const [dataGraphMatoa, setDataGraphMatoa] = useState({ poi_agg: [], kpdl_agg: [] })
useEffect(() => {
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/propinsi",
method: "GET",
dataType: "json",
success: (data) => {
7 months ago
setProp(data)
7 months ago
}
7 months ago
})
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/zpkanwil",
method: "GET",
dataType: "json",
success: (data) => {
7 months ago
setKanwil(data)
7 months ago
}
7 months ago
})
}, [])
useEffect(() => {
setKota({})
setKec([])
setKel([])
setKotaSelected({})
setKecSelected([])
setKelSelected([])
if (propSelected && !isObjEmpty(propSelected)) {
const prop = propSelected.value
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/kota",
7 months ago
method: "GET",
dataType: "json",
data: { prop },
7 months ago
success: (data) => {
7 months ago
setKota(data)
7 months ago
}
7 months ago
})
}
}, [propSelected])
useEffect(() => {
setKec([])
setKel([])
setKecSelected([])
setKelSelected([])
if (kotaSelected && !isObjEmpty(kotaSelected)) {
const kota = kotaSelected.value
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/kecamatan",
7 months ago
method: "GET",
dataType: "json",
data: { kota },
7 months ago
success: (data) => {
7 months ago
setKec(data)
7 months ago
}
7 months ago
})
}
}, [kotaSelected])
useEffect(() => {
setKel([])
setKelSelected([])
console.log({ kecSelected })
if (kecSelected.length && !isObjEmpty(kecSelected)) {
7 months ago
const kec = collect(kecSelected).pluck("value").all()
7 months ago
console.log({ kec })
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/kelurahan",
7 months ago
method: "GET",
dataType: "json",
data: { kec },
7 months ago
success: (data) => {
7 months ago
setKel(data)
7 months ago
}
7 months ago
})
}
}, [kecSelected])
useEffect(() => {
setKpp([])
setSeksi([])
setAr([])
setZp([])
setKppSelected([])
setSeksiSelected([])
setArSelected([])
setZpSelected([])
if (kanwilSelected && !isObjEmpty(kanwilSelected)) {
const kanwil = kanwilSelected.value
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/zpkpp",
7 months ago
method: "GET",
dataType: "json",
data: { kanwil },
7 months ago
success: (data) => {
7 months ago
setKpp(data)
7 months ago
}
7 months ago
})
}
}, [kanwilSelected])
useEffect(() => {
setSeksi([])
setAr([])
setZp([])
setSeksiSelected([])
setArSelected([])
setZpSelected([])
if (kppSelected && !isObjEmpty(kppSelected)) {
7 months ago
const kpp = collect(kppSelected).pluck("value").all()
7 months ago
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/zpseksi",
7 months ago
method: "GET",
dataType: "json",
data: { kpp },
7 months ago
success: (data) => {
7 months ago
setSeksi(data)
7 months ago
}
7 months ago
})
}
}, [kppSelected])
useEffect(() => {
setAr([])
setZp([])
setArSelected([])
setZpSelected([])
if (seksiSelected && !isObjEmpty(seksiSelected)) {
7 months ago
const kpp = collect(kppSelected).pluck("value").all()
const seksi = collect(seksiSelected).pluck("value").all()
7 months ago
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/zpar",
7 months ago
method: "GET",
dataType: "json",
data: { kpp, seksi },
7 months ago
success: (data) => {
7 months ago
setAr(data)
7 months ago
}
7 months ago
})
}
}, [seksiSelected])
useEffect(() => {
setZp([])
setZpSelected([])
if (arSelected && !isObjEmpty(arSelected)) {
7 months ago
const kpp = collect(kppSelected).pluck("value").all()
const seksi = collect(seksiSelected).pluck("value").all()
const ar = collect(arSelected).pluck("value").all()
7 months ago
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/ref/zpzp",
7 months ago
method: "GET",
dataType: "json",
data: { kpp, seksi, ar },
7 months ago
success: (data) => {
7 months ago
setZp(data)
7 months ago
}
7 months ago
})
}
}, [arSelected])
const buttonProsesOnClick = () => {
const opsiWilZona = active
7 months ago
const adm4_pcode = collect(kelSelected).pluck("value").all()
const id_poly_zona = collect(zpSelected).pluck("value").all()
7 months ago
switch (opsiWilZona) {
7 months ago
case "wilayah":
7 months ago
if (adm4_pcode.length) {
7 months ago
setDataSend({ opsiWilZona: "wilayah", adm4_pcode, id_poly_zona: [] })
7 months ago
} else {
7 months ago
toast.current.show({ severity: "info", summary: "Info", detail: "Kelurahan harus dipilih" })
7 months ago
}
7 months ago
break
case "zona":
7 months ago
if (id_poly_zona.length) {
7 months ago
setDataSend({ opsiWilZona: "zona", adm4_pcode: [], id_poly_zona })
7 months ago
} else {
7 months ago
toast.current.show({ severity: "info", summary: "Info", detail: "Zona harus dipilih" })
7 months ago
}
7 months ago
break
7 months ago
default:
7 months ago
break
7 months ago
}
}
useEffect(() => {
Highcharts.setOptions({
lang: {
7 months ago
decimalPoint: ",",
thousandsSep: ".",
7 months ago
numericSymbols: ["rb", "jt", "M", "T", "P", "E"]
},
tooltip: {
yDecimals: 2 // If you want to add 2 decimals
}
})
jQuery.ajax({
7 months ago
url: base_url + "kewilayahan/kytp/graph_matoa",
7 months ago
dataType: "json",
type: "POST",
7 months ago
data: { ...dataSend },
7 months ago
success: (data) => {
setDataGraphMatoa(data)
}
})
7 months ago
}, [dataSend])
7 months ago
const optionsGraphMatoaAgg = {
chart: {
7 months ago
zoomType: "xy",
height: "320"
7 months ago
},
title: {
7 months ago
text: "Poi Google dan Matoa"
7 months ago
// align: 'center'
},
7 months ago
xAxis: [
{
categories: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
crosshair: true
}
],
7 months ago
yAxis: [
{
gridLineWidth: 0,
title: {
7 months ago
text: "",
7 months ago
style: {
color: Highcharts.getOptions().colors[0]
}
},
labels: {
//format: '{value}',
style: {
color: Highcharts.getOptions().colors[0]
}
},
visible: false
},
{
labels: {
//format: '{value}',
style: {
color: Highcharts.getOptions().colors[1]
}
},
title: {
7 months ago
text: "NPWP Work True",
7 months ago
style: {
color: Highcharts.getOptions().colors[1]
}
},
opposite: true,
visible: false
},
{
gridLineWidth: 0,
title: {
7 months ago
text: "Rupiah",
7 months ago
style: {
color: Highcharts.getOptions().colors[2]
}
},
labels: {
//format: '{value}',
style: {
color: Highcharts.getOptions().colors[2]
}
},
opposite: true,
visible: false
},
{
gridLineWidth: 0,
title: {
7 months ago
text: "",
7 months ago
style: {
color: "#FF0000"
}
},
labels: {
//format: '{value}',
style: {
color: "##FF0000"
}
},
opposite: true
}
],
tooltip: {
shared: true
},
legend: {
7 months ago
layout: "horizontal",
align: "center",
7 months ago
//x: 80,
7 months ago
verticalAlign: "top",
7 months ago
//y: 55,
//floating: true,
backgroundColor:
Highcharts.defaultOptions.legend.backgroundColor || // theme
7 months ago
"rgba(255,255,255,0.25)"
7 months ago
},
7 months ago
series: [
{
color: "#FF0000",
name: "Jml PoI",
type: "column",
yAxis: 3,
data: dataGraphMatoa.poi_agg,
marker: {
enabled: true
7 months ago
},
7 months ago
tooltip: {
valueSuffix: " PoI"
}
7 months ago
},
7 months ago
{
name: "Matoa",
type: "spline",
yAxis: 3,
data: dataGraphMatoa.kpdl_agg,
marker: {
enabled: true
},
tooltip: {
pointFormatter: function () {
const idx = this.index
let pct_coverage
const jml_poi_agg = dataGraphMatoa.poi_agg
if (jml_poi_agg[idx] && jml_poi_agg[idx] !== 0) {
pct_coverage = format_angka(parseFloat((parseFloat(this.y) / jml_poi_agg[idx]) * 100).toFixed(2)) + "%"
}
let s =
'<span style="color:' +
this.color +
'">\u25CF</span> ' +
this.series.name +
": <b>" +
format_angka(this.y) +
" lokasi kpdl</b> " +
(pct_coverage ? "(" + pct_coverage + ")<br>\n" : "<br>")
return s
},
shared: false
},
visible: true,
color: "#8000ff"
}
]
7 months ago
}
7 months ago
return (
<>
<Row className="text-center">
<Col>
<h2>E-Geospatial Thematic Tax</h2>
</Col>
</Row>
<Row>
<Col sm="12">
<Card>
<CardBody>
<Nav tabs>
<NavItem>
<NavLink
style={{ cursor: "pointer" }}
active={active === "wilayah"}
onClick={() => {
toggle("wilayah")
}}
>
Wilayah Adm.
</NavLink>
</NavItem>
<NavItem>
<NavLink
style={{ cursor: "pointer" }}
active={active === "zona"}
onClick={() => {
toggle("zona")
}}
>
Zona Pengawasan
</NavLink>
</NavItem>
</Nav>
<TabContent className="py-3" activeTab={active}>
<TabPane tabId="wilayah">
<Row>
<Col md="3">
<Label className="form-label" for="basicInput">
Propinsi
</Label>
<Select
placeholder="Pilih Propinsi"
className="basic-single w-100"
onChange={(e) => {
setPropSelected(e)
}}
classNamePrefix="select"
defaultValue={propSelected}
value={propSelected}
isClearable={false}
options={prop}
/>
</Col>
<Col md="3">
<Label className="form-label" for="basicInput">
Kota/Kab
</Label>
<Select
placeholder="Pilih Kota/Kab"
className="basic-single w-100"
onChange={(e) => {
setKotaSelected(e)
}}
classNamePrefix="select"
defaultValue={kotaSelected}
value={kotaSelected}
isClearable={false}
options={kota}
/>
</Col>
<Col md="3">
<Label className="form-label" for="Pilih Kecamatan">
Kecamatan
</Label>
<MultiSelect
className="me-1 w-full"
hasSelectAll={true}
debounceDuration={300}
options={kec}
value={kecSelected}
onChange={(e) => {
setKecSelected(e)
}}
labelledBy="Pilih Kecamatan"
overrideStrings={{ allItemsAreSelected: "Semua dipilih", selectSomeItems: "Pilih Kecamatan" }}
/>
</Col>
<Col md="3">
<Label className="form-label" for="Pilih Kelurahan">
Kelurahan
</Label>
<MultiSelect
className="me-1 w-full"
hasSelectAll={true}
debounceDuration={300}
options={kel}
value={kelSelected}
onChange={(e) => {
setKelSelected(e)
}}
labelledBy="Pilih Kelurahan"
overrideStrings={{ allItemsAreSelected: "Semua dipilih", selectSomeItems: "Pilih Kelurahan" }}
/>
</Col>
</Row>
<Row className="mt-2">
<Col sm="12">
<ButtonP onClick={() => buttonProsesOnClick()} label="Proses" severity="" rounded className="w-10rem text-white text-base" />
</Col>
</Row>
</TabPane>
<TabPane tabId="zona">
<Row>
<Col md="2">
<Label className="form-label" for="basicInput">
Kanwil
</Label>
<Select
placeholder="Pilih Kanwil"
className="basic-single w-100"
onChange={(e) => {
setKanwilSelected(e)
}}
classNamePrefix="select"
defaultValue={kanwilSelected}
value={kanwilSelected}
isClearable={false}
options={kanwil}
/>
</Col>
<Col md="2">
<Label className="form-label" for="Pilih KPP">
KPP
</Label>
<MultiSelect
className="me-1 w-full"
hasSelectAll={true}
debounceDuration={300}
options={kpp}
value={kppSelected}
onChange={(e) => {
setKppSelected(e)
}}
labelledBy="Pilih KPP"
overrideStrings={{ allItemsAreSelected: "Semua dipilih", selectSomeItems: "Pilih KPP" }}
/>
</Col>
<Col md="2">
<Label className="form-label" for="Pilih Seksi">
Seksi
</Label>
<MultiSelect
className="me-1 w-full"
hasSelectAll={true}
debounceDuration={300}
options={seksi}
value={seksiSelected}
onChange={(e) => {
setSeksiSelected(e)
}}
labelledBy="Pilih Seksi"
overrideStrings={{ allItemsAreSelected: "Semua dipilih", selectSomeItems: "Pilih Seksi" }}
/>
</Col>
<Col md="3">
<Label className="form-label" for="Pilih AR">
AR
</Label>
<MultiSelect
className="me-1 w-full"
hasSelectAll={true}
debounceDuration={300}
options={ar}
value={arSelected}
onChange={(e) => {
setArSelected(e)
}}
labelledBy="Pilih AR"
overrideStrings={{ allItemsAreSelected: "Semua dipilih", selectSomeItems: "Pilih AR" }}
/>
</Col>
<Col md="3">
<Label className="form-label" for="Pilih Zona">
Zona Pengawasan
</Label>
<MultiSelect
className="me-1 w-full"
hasSelectAll={true}
debounceDuration={300}
options={zp}
value={zpSelected}
onChange={(e) => {
setZpSelected(e)
}}
labelledBy="Pilih Zona"
overrideStrings={{ allItemsAreSelected: "Semua dipilih", selectSomeItems: "Pilih Zona" }}
/>
</Col>
</Row>
<Row className="mt-2">
<Col sm="12">
<ButtonP onClick={() => buttonProsesOnClick()} label="Proses" severity="" rounded className="w-10rem text-white text-base" />
</Col>
</Row>
</TabPane>
</TabContent>
</CardBody>
</Card>
</Col>
</Row>
<Row>
<Col sm="12">
<Card>
<CardBody>
<div id="graph_matoa_agg">
<HighchartsReact ref={refChart1} highcharts={Highcharts} options={optionsGraphMatoaAgg} />
</div>
</CardBody>
</Card>
</Col>
</Row>
<Row>
<Col sm="12">
<Card>
<CardHeader className="d-flex justify-content-center">
<CardTitle tag={"h1"} className="font-weight-bold">
Statistik Progresifitas Hasil Kegiatan Matoa
</CardTitle>
</CardHeader>
<CardBody>
<TabProgresifitas dataSend={dataSend} />
</CardBody>
</Card>
</Col>
</Row>
<Row>
<Col sm="12">
<Card>
<CardBody>
<TabPenugasan dataSend={dataSend} />
</CardBody>
</Card>
</Col>
</Row>
<Toast ref={toast} />
</>
)
7 months ago
}
const container = document.getElementById("app")
const component = <Root />
7 months ago
ReactDOM.render(component, container)