20 changed files with 64189 additions and 427 deletions
@ -0,0 +1,91 @@
|
||||
module.exports = { |
||||
parser: "@babel/eslint-parser", |
||||
env: { |
||||
node: true, |
||||
es6: true, |
||||
browser: true |
||||
}, |
||||
parserOptions: { |
||||
ecmaVersion: 2020, |
||||
sourceType: "module", |
||||
requireConfigFile: false, |
||||
ecmaFeatures: { |
||||
jsx: true, |
||||
modules: true, |
||||
experimentalObjectRestSpread: true |
||||
}, |
||||
babelOptions: { |
||||
presets: ["@babel/preset-react"] |
||||
} |
||||
}, |
||||
rules: { |
||||
"no-console": "off", |
||||
"no-debugger": process.env.NODE_ENV === "production" ? "error" : "off", |
||||
|
||||
// Best Practices
|
||||
eqeqeq: "error", |
||||
"no-invalid-this": "error", |
||||
"no-return-assign": "error", |
||||
"no-unused-expressions": ["error", { allowTernary: true }], |
||||
"no-useless-concat": "error", |
||||
"no-useless-return": "error", |
||||
|
||||
// Variable
|
||||
// 'init-declarations': 'error',
|
||||
"no-use-before-define": "error", |
||||
|
||||
"no-unused-vars": ["error", { varsIgnorePattern: "^[A-Z]" }], |
||||
|
||||
// Stylistic Issues
|
||||
"array-bracket-newline": ["error", { multiline: true, minItems: null }], |
||||
"array-bracket-spacing": "error", |
||||
"brace-style": ["error", "1tbs", { allowSingleLine: true }], |
||||
"block-spacing": "error", |
||||
"comma-dangle": "error", |
||||
"comma-spacing": "error", |
||||
"comma-style": "error", |
||||
"computed-property-spacing": "error", |
||||
"func-call-spacing": "error", |
||||
"implicit-arrow-linebreak": ["error", "beside"], |
||||
// indent: ['error', 4],
|
||||
"keyword-spacing": "error", |
||||
"multiline-ternary": ["error", "never"], |
||||
// 'no-lonely-if': 'error',
|
||||
"no-mixed-operators": "error", |
||||
"no-multiple-empty-lines": ["error", { max: 2, maxEOF: 1 }], |
||||
"no-tabs": "error", |
||||
"no-unneeded-ternary": "error", |
||||
"no-whitespace-before-property": "error", |
||||
"nonblock-statement-body-position": "error", |
||||
"object-property-newline": [ |
||||
"error", |
||||
{ allowAllPropertiesOnSameLine: true } |
||||
], |
||||
"quote-props": ["error", "as-needed"], |
||||
// quotes: ['error', 'prefer-single'],
|
||||
semi: ["error", "never"], |
||||
"semi-spacing": "error", |
||||
"space-before-blocks": "error", |
||||
// 'space-before-function-paren': 'error',
|
||||
"space-in-parens": "error", |
||||
"space-infix-ops": 0, |
||||
"space-unary-ops": "error", |
||||
|
||||
// ES6
|
||||
"arrow-spacing": "error", |
||||
"no-confusing-arrow": "error", |
||||
"no-duplicate-imports": "error", |
||||
"no-var": "error", |
||||
"object-shorthand": "error", |
||||
"prefer-const": "error", |
||||
"prefer-template": "error" |
||||
} |
||||
|
||||
// rules: {
|
||||
// 'no-console': process.env.NODE_ENV === 'production' ? 'error' : 'off',
|
||||
// 'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off',
|
||||
// semi: ['error', 'never'],
|
||||
// 'max-len': 'off',
|
||||
// camelcase: ['error', { properties: 'never', ignoreDestructuring: true, ignoreImports: true }]
|
||||
// }
|
||||
} |
@ -0,0 +1,9 @@
|
||||
{ |
||||
"tabWidth": 2, |
||||
"useTabs": false, |
||||
"semi": false, |
||||
"trailingComma": "none", |
||||
"comma-dangle": false, |
||||
"printWidth": 160, |
||||
"bracketSpacing": true |
||||
} |
@ -1,11 +1,21 @@
|
||||
{ |
||||
"editor.wordWrap": "on", |
||||
"chat.editor.wordWrap": "on", |
||||
"editor.formatOnPaste": true, |
||||
"editor.defaultFormatter": "esbenp.prettier-vscode", |
||||
"editor.formatOnSave": true, |
||||
"phpfmt.php_bin": "\"C:/xampp/php/php.exe\"", |
||||
"[php]": { |
||||
"editor.defaultFormatter": "kokororin.vscode-phpfmt" |
||||
"editor.formatOnSave": true |
||||
}, |
||||
"phpfmt.enable_auto_align": true, |
||||
"phpfmt.detect_indent": false, |
||||
"phpfmt.indent_with_space": 4, |
||||
"prettier.singleQuote": true, |
||||
"prettier.useTabs": true, |
||||
"editor.formatOnSave": true, |
||||
"[javascript]": { |
||||
"editor.defaultFormatter": "esbenp.prettier-vscode", |
||||
"editor.formatOnSave": true |
||||
}, |
||||
"[typescriptreact]":{ |
||||
"editor.defaultFormatter" : "esbenp.prettier-vscode", |
||||
"editor.formatOnSave": true |
||||
}, |
||||
"editor.formatOnType": true |
||||
|
||||
} |
||||
|
@ -0,0 +1,41 @@
|
||||
<?php |
||||
namespace App\Controllers\Kewilayahan\Sebaran; |
||||
|
||||
class Identifikasi extends \App\Controllers\Kewilayahan\Kytp |
||||
|
||||
{ |
||||
protected function data($request) |
||||
{ |
||||
$opsiWilZona = $request->getPost('opsiWilZona'); |
||||
$adm4_pcode = $request->getPost('adm4_pcode') ?? []; |
||||
$id_poly_zona = $request->getPost('id_poly_zona') ?? []; |
||||
|
||||
$db = \Config\Database::connect(); |
||||
|
||||
$npwp = $db->table('KPDL_MV_LOKASI_SUBJEK')->select("CASE WHEN (NPWP IS NULL) THEN 'NON NPWP' ELSE 'BER NPWP' END AS IDENTIFIKASI, count(1) JML", false) |
||||
->groupBy("CASE WHEN (NPWP IS NULL) THEN 'NON NPWP' ELSE 'BER NPWP' END"); |
||||
|
||||
if ($opsiWilZona == 'wilayah') { |
||||
$npwp->whereIn('ADM4_PCODE', $adm4_pcode); |
||||
} |
||||
|
||||
if ($opsiWilZona == 'zona') { |
||||
$npwp->whereIn('ID_POLY_ZONA', $id_poly_zona); |
||||
} |
||||
|
||||
$data = $npwp->get()->getResult(); |
||||
|
||||
$ret = []; |
||||
|
||||
foreach ($data as $b) { |
||||
|
||||
array_push($ret, ['name' => $b->IDENTIFIKASI, |
||||
'color' => $b->IDENTIFIKASI == 'NON NPWP' ? 'orange' : 'green', |
||||
'y' => floatval($b->JML), |
||||
] |
||||
); |
||||
} |
||||
|
||||
return $ret; |
||||
} |
||||
} |
@ -0,0 +1,49 @@
|
||||
<?php |
||||
namespace App\Controllers\Kewilayahan\Sebaran; |
||||
|
||||
use CodeIgniter\Database\RawSql; |
||||
|
||||
class PayComp extends \App\Controllers\Kewilayahan\Kytp |
||||
|
||||
{ |
||||
protected function dataC($request, $tahun, $bulan) |
||||
{ |
||||
$opsiWilZona = $request->getPost('opsiWilZona'); |
||||
$adm4_pcode = $request->getPost('adm4_pcode') ?? []; |
||||
$id_poly_zona = $request->getPost('id_poly_zona') ?? []; |
||||
|
||||
$db = \Config\Database::connect(); |
||||
//npwp |
||||
$npwp = $db->table('KPDL_MV_LOKASI_SUBJEK')->select('NPWP')->distinct()->where('NPWP IS NOT NULL'); |
||||
|
||||
if ($opsiWilZona == 'wilayah') { |
||||
$npwp->whereIn('ADM4_PCODE', $adm4_pcode); |
||||
} |
||||
|
||||
if ($opsiWilZona == 'zona') { |
||||
$npwp->whereIn('ID_POLY_ZONA', $id_poly_zona); |
||||
} |
||||
|
||||
$data = $db->newQuery() |
||||
->select("'" . $tahun . '-' . $bulan . "' AS THN_BLN, B.JML|| ' bulan' as KETERANGAN, COUNT(1) AS Y", false) |
||||
->fromSubquery($npwp, 'A') |
||||
->join('KPDL_MV_PENERIMAAN_AGG_PC B', new RawSql("A.NPWP=B.NPWP and B.THNBYR = " . $tahun . " and B.BULAN=" . $bulan), 'inner') |
||||
->groupBy("B.JML")->orderBy("KETERANGAN"); |
||||
|
||||
$data = $data->get()->getResult(); |
||||
|
||||
$ret = []; |
||||
|
||||
foreach ($data as $b) { |
||||
|
||||
array_push($ret, ['name' => $b->KETERANGAN, |
||||
// 'color' => $b->WARNA_BYR, |
||||
'y' => floatval($b->Y), |
||||
'thn_bln' => $b->THN_BLN, |
||||
] |
||||
); |
||||
} |
||||
|
||||
return $ret; |
||||
} |
||||
} |
@ -0,0 +1,70 @@
|
||||
<?php |
||||
namespace App\Controllers\Kewilayahan\Sebaran; |
||||
|
||||
use CodeIgniter\Database\RawSql; |
||||
|
||||
class Pembayaran extends \App\Controllers\Kewilayahan\Kytp |
||||
|
||||
{ |
||||
protected function dataC($request, $tahun, $bulan) |
||||
{ |
||||
$opsiWilZona = $request->getPost('opsiWilZona'); |
||||
$adm4_pcode = $request->getPost('adm4_pcode') ?? []; |
||||
$id_poly_zona = $request->getPost('id_poly_zona') ?? []; |
||||
// $tahun = $this->request->getPost('tahun') ?? date('Y'); |
||||
// $bulan = $this->request->getPost('bulan') ?? date('m'); |
||||
|
||||
// $opsiWilZona = ''; |
||||
// $adm4_pcode = ''; |
||||
// $id_poly_zona = ''; |
||||
// $tahun = date('Y'); |
||||
// $bulan = date('m'); |
||||
|
||||
$db = \Config\Database::connect(); |
||||
//npwp |
||||
$npwp = $db->table('KPDL_MV_LOKASI_SUBJEK')->select('NPWP')->distinct()->where('NPWP IS NOT NULL'); |
||||
|
||||
if ($opsiWilZona == 'wilayah') { |
||||
$npwp->whereIn('ADM4_PCODE', $adm4_pcode); |
||||
} |
||||
|
||||
if ($opsiWilZona == 'zona') { |
||||
$npwp->whereIn('ID_POLY_ZONA', $id_poly_zona); |
||||
} |
||||
|
||||
$data = $db->newQuery() |
||||
->select("'" . $tahun . '-' . $bulan . "' AS THN_BLN, NVL(WARNA_BYR, 'black') WARNA_BYR, COUNT(1) AS Y") |
||||
->fromSubquery($npwp, 'A') |
||||
->join('KPDL_MV_PENERIMAAN_AGG B', new RawSql("A.NPWP=B.NPWP and B.THNBYR = " . $tahun . " and B.BULAN=" . $bulan), 'left') |
||||
->groupBy("NVL(WARNA_BYR, 'black')")->orderBy("WARNA_BYR"); |
||||
|
||||
$data = $data->get()->getResult(); |
||||
|
||||
$ret = []; |
||||
|
||||
foreach ($data as $b) { |
||||
$name = ''; |
||||
switch ($b->WARNA_BYR) { |
||||
case 'black':$name = '<=0'; |
||||
break; |
||||
case 'red':$name = '< 5 jt'; |
||||
break; |
||||
case 'yellow':$name = '<48 jt'; |
||||
break; |
||||
case 'green':$name = '<100 jt'; |
||||
break; |
||||
case 'blue':$name = '> 100 jt'; |
||||
break; |
||||
} |
||||
|
||||
array_push($ret, ['name' => $name, |
||||
'color' => $b->WARNA_BYR, |
||||
'y' => floatval($b->Y), |
||||
'thn_bln' => $b->THN_BLN, |
||||
] |
||||
); |
||||
} |
||||
|
||||
return $ret; |
||||
} |
||||
} |
@ -0,0 +1,61 @@
|
||||
<?php |
||||
namespace App\Controllers\Kewilayahan\Sebaran; |
||||
|
||||
use CodeIgniter\Database\RawSql; |
||||
|
||||
class Sof extends \App\Controllers\Kewilayahan\Kytp |
||||
|
||||
{ |
||||
protected function dataC($request, $tahun, $bulan) |
||||
{ |
||||
$opsiWilZona = $request->getPost('opsiWilZona'); |
||||
$adm4_pcode = $request->getPost('adm4_pcode') ?? []; |
||||
$id_poly_zona = $request->getPost('id_poly_zona') ?? []; |
||||
|
||||
$db = \Config\Database::connect(); |
||||
//npwp |
||||
$npwp = $db->table('KPDL_MV_LOKASI_SUBJEK')->select('NPWP')->distinct()->where('NPWP IS NOT NULL'); |
||||
|
||||
if ($opsiWilZona == 'wilayah') { |
||||
$npwp->whereIn('ADM4_PCODE', $adm4_pcode); |
||||
} |
||||
|
||||
if ($opsiWilZona == 'zona') { |
||||
$npwp->whereIn('ID_POLY_ZONA', $id_poly_zona); |
||||
} |
||||
|
||||
$sqlBulanIni = $db->newQuery() |
||||
->select("'" . $tahun . '-' . $bulan . "' AS THN_BLN, B.LAPISAN, count(1) JML", false) |
||||
->fromSubquery($npwp, 'A') |
||||
->join("KPDL_MV_PENERIMAAN_AGG_SF B", new RawSql("A.NPWP=B.NPWP and B.THNBYR = " . $tahun . " and B.BULAN=" . $bulan), 'inner') |
||||
->groupBy("B.LAPISAN")->getCompiledSelect(); |
||||
|
||||
$sqlBulanLalu = $db->newQuery() |
||||
->select("'" . $tahun . '-' . $bulan - 1 . "' AS THN_BLN, B.LAPISAN, count(1) JML", false) |
||||
->fromSubquery($npwp, 'A') |
||||
->join("KPDL_MV_PENERIMAAN_AGG_SF B", new RawSql("A.NPWP=B.NPWP and B.THNBYR = " . $tahun . " and B.BULAN=" . $bulan - 1), 'inner') |
||||
->groupBy("B.LAPISAN")->getCompiledSelect(); |
||||
|
||||
$sql2BulanLalu = $db->newQuery() |
||||
->select("'" . $tahun . '-' . $bulan - 2 . "' AS THN_BLN, B.LAPISAN, count(1) JML", false) |
||||
->fromSubquery($npwp, 'A') |
||||
->join("KPDL_MV_PENERIMAAN_AGG_SF B", new RawSql("A.NPWP=B.NPWP and B.THNBYR = " . $tahun . " and B.BULAN=" . $bulan - 2), 'inner') |
||||
->groupBy("B.LAPISAN")->getCompiledSelect(); |
||||
|
||||
$sqlSemua = $db->newQuery() |
||||
->select("L.LAPISAN , NVL(A.JML, 0) AS JML_C, NVL(B.JML,0) JML_P1, NVL(C.JML,0) JML_P2") |
||||
->from('KPDL_REF_LAPISAN L') |
||||
->join("(" . $sqlBulanIni . ") A", "L.LAPISAN = A.LAPISAN", "left", false) |
||||
->join("(" . $sqlBulanLalu . ") B", "L.LAPISAN = B.LAPISAN", "left", false) |
||||
->join("(" . $sql2BulanLalu . ") C", "L.LAPISAN = C.LAPISAN", "left", false) |
||||
->orderBy("L.LAPISAN"); |
||||
|
||||
$data = $sqlSemua->get()->getResult(); |
||||
foreach ($data as $key => $value) { |
||||
$value->JML_C = floatval($value->JML_C); |
||||
$value->JML_P1 = floatval($value->JML_P1); |
||||
$value->JML_P2 = floatval($value->JML_P2); |
||||
} |
||||
return $data; |
||||
} |
||||
} |
File diff suppressed because one or more lines are too long
@ -0,0 +1,14 @@
|
||||
import React, { useState } from "react" |
||||
import { TabView, TabPanel } from "primereact/tabview" |
||||
|
||||
export default function TabPenugasan({ dataSend }) { |
||||
return ( |
||||
<div className="card"> |
||||
<TabView> |
||||
<TabPanel id="tab_1" header="Penugasan"></TabPanel> |
||||
<TabPanel id="tab_2" header="Aktifitas"></TabPanel> |
||||
<TabPanel id="tab_3" header="Hasil"></TabPanel> |
||||
</TabView> |
||||
</div> |
||||
) |
||||
} |
@ -0,0 +1,83 @@
|
||||
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 Identifikasi = ({ dataSend }) => { |
||||
const base_url = "<?=base_url()?>" |
||||
|
||||
const refChart = useRef(null) |
||||
const [data, setData] = useState(null) |
||||
|
||||
useEffect(() => { |
||||
jQuery.get({ |
||||
url: base_url + "kewilayahan/kytp/sebaranIdentifikasi", |
||||
dataType: "json", |
||||
type: "POST", |
||||
data: { |
||||
...dataSend |
||||
}, |
||||
success: (data) => { |
||||
console.log(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 lokasi Matoa" |
||||
}, |
||||
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, "Identifikasi Lokasi Matoa")} /> |
||||
</Col> |
||||
</Row> |
||||
</> |
||||
) |
||||
} |
||||
|
||||
export default Identifikasi |
@ -0,0 +1,97 @@
|
||||
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" |
||||
const date = new Date() |
||||
const cBulan = date.getMonth() + 1 |
||||
|
||||
const PayComp = ({ dataSend }) => { |
||||
const base_url = "<?=base_url()?>" |
||||
|
||||
const refChart = useRef(null) |
||||
const [dataC, setDataC] = useState(null) |
||||
const [dataMin1, setDataMin1] = useState(null) |
||||
const [dataMin2, setDataMin2] = useState(null) |
||||
|
||||
useEffect(() => { |
||||
jQuery.get({ |
||||
url: base_url + "kewilayahan/kytp/sebaranPayComp", |
||||
dataType: "json", |
||||
type: "POST", |
||||
data: { |
||||
...dataSend, |
||||
tahun: date.getFullYear(), |
||||
bulan: cBulan |
||||
}, |
||||
success: (data) => { |
||||
setDataC(data.dataC) |
||||
setDataMin1(data.dataMin1) |
||||
setDataMin2(data.dataMin2) |
||||
} |
||||
}) |
||||
}, [dataSend]) |
||||
|
||||
const optionsChart = (data, title, type) => { |
||||
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>Jml NPWP : {point.y} dari " + format_angka(total_wp) + " yang terdapat data penerimaannya" |
||||
}, |
||||
accessibility: { |
||||
point: { |
||||
valueSuffix: "%" |
||||
} |
||||
}, |
||||
plotOptions: { |
||||
pie: { |
||||
allowPointSelect: true, |
||||
cursor: "pointer", |
||||
// colors: warna_garis,
|
||||
dataLabels: { |
||||
enabled: true, |
||||
style: { fontSize: "0.7rem" }, |
||||
format: "{point.name}: <br> {point.percentage:.1f} %" |
||||
} |
||||
//showInLegend: true
|
||||
} |
||||
// series: pie_click
|
||||
}, |
||||
series: [ |
||||
{ |
||||
name: type, |
||||
data |
||||
} |
||||
] |
||||
} |
||||
} |
||||
return ( |
||||
<> |
||||
<Row> |
||||
<Col> |
||||
<HighchartsReact ref={refChart} highcharts={Highcharts} options={optionsChart(dataC, "s.d. bulan ini", "C")} /> |
||||
</Col> |
||||
<Col> |
||||
<HighchartsReact ref={refChart} highcharts={Highcharts} options={optionsChart(dataMin1, "s.d. bulan lalu", "Min1")} /> |
||||
</Col> |
||||
<Col> |
||||
<HighchartsReact ref={refChart} highcharts={Highcharts} options={optionsChart(dataMin2, "s.d. 2 bulan yang lalu", "Min2")} /> |
||||
</Col> |
||||
</Row> |
||||
</> |
||||
) |
||||
} |
||||
|
||||
export default PayComp |
@ -0,0 +1,97 @@
|
||||
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" |
||||
const date = new Date() |
||||
const cBulan = date.getMonth() + 1 |
||||
|
||||
const Pembayaran = ({ dataSend }) => { |
||||
const base_url = "<?=base_url()?>" |
||||
|
||||
const refChart = useRef(null) |
||||
const [dataC, setDataC] = useState(null) |
||||
const [dataMin1, setDataMin1] = useState(null) |
||||
const [dataMin2, setDataMin2] = useState(null) |
||||
|
||||
useEffect(() => { |
||||
jQuery.get({ |
||||
url: base_url + "kewilayahan/kytp/sebaranPembayaran", |
||||
dataType: "json", |
||||
type: "POST", |
||||
data: { |
||||
...dataSend, |
||||
tahun: date.getFullYear(), |
||||
bulan: cBulan |
||||
}, |
||||
success: (data) => { |
||||
setDataC(data.dataC) |
||||
setDataMin1(data.dataMin1) |
||||
setDataMin2(data.dataMin2) |
||||
} |
||||
}) |
||||
}, [dataSend]) |
||||
|
||||
const optionsChart = (data, title, type) => { |
||||
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>Jml NPWP : {point.y} dari " + format_angka(total_wp) |
||||
}, |
||||
accessibility: { |
||||
point: { |
||||
valueSuffix: "%" |
||||
} |
||||
}, |
||||
plotOptions: { |
||||
pie: { |
||||
allowPointSelect: true, |
||||
cursor: "pointer", |
||||
//colors : warna_garis,
|
||||
dataLabels: { |
||||
enabled: true, |
||||
style: { fontSize: "10px" }, |
||||
format: "{point.name}: <br> {point.percentage:.1f} %" |
||||
} |
||||
// showInLegend: true
|
||||
} |
||||
// series: pie_click
|
||||
}, |
||||
series: [ |
||||
{ |
||||
name: type, |
||||
data |
||||
} |
||||
] |
||||
} |
||||
} |
||||
return ( |
||||
<> |
||||
<Row> |
||||
<Col> |
||||
<HighchartsReact ref={refChart} highcharts={Highcharts} options={optionsChart(dataC, "s.d. bulan ini", "C")} /> |
||||
</Col> |
||||
<Col> |
||||
<HighchartsReact ref={refChart} highcharts={Highcharts} options={optionsChart(dataMin1, "s.d. bulan lalu", "Min1")} /> |
||||
</Col> |
||||
<Col> |
||||
<HighchartsReact ref={refChart} highcharts={Highcharts} options={optionsChart(dataMin2, "s.d. 2 bulan yang lalu", "Min2")} /> |
||||
</Col> |
||||
</Row> |
||||
</> |
||||
) |
||||
} |
||||
|
||||
export default Pembayaran |
@ -0,0 +1,109 @@
|
||||
import React, { useEffect, useRef, useState } from "react" |
||||
import { Col, Row, Table } from "reactstrap" |
||||
import { format_angka } from "../util" |
||||
import collect from "collect.js" |
||||
const date = new Date() |
||||
const cBulan = date.getMonth() + 1 |
||||
|
||||
const Sof = ({ dataSend }) => { |
||||
const base_url = "<?=base_url()?>" |
||||
|
||||
const [data, setData] = useState([]) |
||||
const [total, setTotal] = useState({ totalC: 0, totalP1: 0, totalP2: 0 }) |
||||
|
||||
useEffect(() => { |
||||
jQuery.get({ |
||||
url: base_url + "kewilayahan/kytp/sebaranSof", |
||||
dataType: "json", |
||||
type: "POST", |
||||
data: { |
||||
...dataSend, |
||||
tahun: date.getFullYear(), |
||||
bulan: cBulan |
||||
}, |
||||
success: (data) => { |
||||
console.log(data) |
||||
setData(data.data) |
||||
setTotal({ |
||||
totalC: collect(data.data).sum("JML_C"), |
||||
totalP1: collect(data.data).sum("JML_P1"), |
||||
totalP2: collect(data.data).sum("JML_P2") |
||||
}) |
||||
} |
||||
}) |
||||
}, [dataSend]) |
||||
|
||||
return ( |
||||
<> |
||||
<Row> |
||||
<Col> |
||||
<div className="d-flex justify-content-center"> |
||||
<Table bordered style={{ width: "auto", fontSize: "0.85rem" }}> |
||||
<thead className="bg-primary text-white"> |
||||
<tr> |
||||
<th class="text-center text-white" rowspan="2"> |
||||
Lapisan |
||||
</th> |
||||
<th class="text-center text-white" colspan="2"> |
||||
s.d Sekarang |
||||
</th> |
||||
<th class="text-center text-white" colspan="2"> |
||||
s.d Bulan Lalu |
||||
</th> |
||||
<th class="text-center text-white" colspan="2"> |
||||
s.d 2 Bulan Lalu |
||||
</th> |
||||
</tr> |
||||
<tr> |
||||
<th class="text-center text-white">Jml WP</th> |
||||
<th class="text-center text-white">%</th> |
||||
<th class="text-center text-white">Jml WP</th> |
||||
<th class="text-center text-white">%</th> |
||||
<th class="text-center text-white">Jml WP</th> |
||||
<th class="text-center text-white">%</th> |
||||
</tr> |
||||
<tr class=""> |
||||
<th class="text-center text-white">1</th> |
||||
<th class="text-center text-white">2</th> |
||||
<th class="text-center text-white">3</th> |
||||
<th class="text-center text-white">4</th> |
||||
<th class="text-center text-white">5</th> |
||||
<th class="text-center text-white">6</th> |
||||
<th class="text-center text-white">7</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
{data.map((val, idx) => { |
||||
return ( |
||||
<tr id={idx}> |
||||
<td class="text-start p-1 font-weight-bold">{val.LAPISAN}</td> |
||||
<td class="text-center p-1">{val.JML_C}</td> |
||||
<td class="text-center p-1">{((val.JML_C / total.totalC) * 100).toFixed(2) + "%"}</td> |
||||
<td class="text-center p-1">{val.JML_P1}</td> |
||||
<td class="text-center p-1">{((val.JML_P1 / total.totalP1) * 100).toFixed(2) + "%"}</td> |
||||
<td class="text-center p-1">{val.JML_P2}</td> |
||||
<td class="text-center p-1">{((val.JML_P2 / total.totalP2) * 100).toFixed(2) + "%"}</td> |
||||
</tr> |
||||
) |
||||
})} |
||||
</tbody> |
||||
<tfoot> |
||||
<tr className="font-weight-bold"> |
||||
<td class="text-center">Total</td> |
||||
<td class="text-center">{total.totalC}</td> |
||||
<td class="text-center">100%</td> |
||||
<td class="text-center">{total.totalP1}</td> |
||||
<td class="text-center">100%</td> |
||||
<td class="text-center">{total.totalP2}</td> |
||||
<td class="text-center">100%</td> |
||||
</tr> |
||||
</tfoot> |
||||
</Table> |
||||
</div> |
||||
</Col> |
||||
</Row> |
||||
</> |
||||
) |
||||
} |
||||
|
||||
export default Sof |
Loading…
Reference in new issue