TKK_E32211868/website/src/pages/Pengujian.tsx

207 lines
5.3 KiB
TypeScript

import { createSignal, onMount } from "solid-js";
import Table from "../components/Table";
import supabase from "../utils/supabase";
import { KondisiTapai } from "../types/KondisiTapai";
import { getDates, getTimes } from "../utils/dates";
import { Chart, registerables } from "chart.js";
export default function () {
let canvas: any;
const [items, setItems] = createSignal<KondisiTapai[]>([]);
const getData = async () => {
const { data } = await supabase
.from("kondisi_tapai")
.select("*")
// .eq("pengujian", true)
.order("created_time", { ascending: true });
setItems(data as KondisiTapai[]);
};
const getLamaJam = (created_time: number) => {
const epochTimeAwal = items()[0].created_time;
let lamaJam = created_time - epochTimeAwal;
lamaJam = Math.round(lamaJam / 3600);
return lamaJam;
};
const getKadarGasRegresi = (jam: number) => {
const nilaiRegresi = (-0.000006 * jam ** 2 + 0.0013 * jam + 0.002) * 100;
const nilaiRegresiPertiga = nilaiRegresi / 3;
return nilaiRegresi - nilaiRegresiPertiga;
};
const renderChart = async () => {
let labels = [];
let kadarRegresi = [];
let kadarAktual: any[] = [];
let jam: any[] = [];
let i = 0;
let j = 0;
items().forEach((item) => {
const lamaJam = getLamaJam(item.created_time);
if (lamaJam % 6 == 0) {
const index = jam.indexOf(lamaJam);
if (index >= 0) {
kadarAktual[index] = item.kadar_gas;
} else {
jam.push(lamaJam);
kadarAktual.push(item.kadar_gas);
}
}
});
while (i <= 72) {
const jamPengujian = jam[j];
const x = jamPengujian || i;
kadarRegresi.push(getKadarGasRegresi(x));
if (typeof jamPengujian == "number") {
labels.push(jamPengujian.toString());
i = jamPengujian + 6;
} else {
labels.push(i.toString());
i += 6;
}
j += 1;
}
new Chart(canvas, {
type: "line",
data: {
labels: labels,
datasets: [
{
label: "Kadar Aktual",
data: kadarAktual,
borderColor: "lightgreen",
cubicInterpolationMode: "monotone",
tension: 0.4,
},
{
label: "Kadar Regresi",
data: kadarRegresi,
borderColor: "#4784f5",
cubicInterpolationMode: "monotone",
tension: 0.4,
},
],
},
options: {
interaction: {
intersect: false,
mode: "index",
},
responsive: true,
scales: {
x: {
display: true,
title: {
display: true,
},
},
y: {
display: true,
title: {
display: true,
text: "Kadar Gas Alkohol",
},
min: 0,
max: 10,
ticks: {
callback: (val) => {
return val + "%";
},
},
},
},
plugins: {
tooltip: {
callbacks: {
title(_) {
return "";
},
label(tooltipItem) {
return (
tooltipItem.dataset.label +
": " +
tooltipItem.parsed.y.toFixed(2) +
"%"
);
},
},
},
},
},
});
};
onMount(async () => {
await getData();
Chart.register(...registerables);
await renderChart();
});
return (
<div class="space-y-5">
<div class="bg-white rounded shadow p-5">
<div class="text-xl">Analisis Data</div>
<p class="text-sm mt-3">
NB : Sistem menampilkan perubahan kandungan dari proses fermentasi
tiap beberapa jam sekali. Jika kadar aktual signifikan (lebih tinggi
atau sama dengan dari kadar regresi), maka proses fermentasi
berpotensi berhasil. Jika kadar aktual dibawah dari kadar regresi,
maka proses fermentasi berpotensi gagal.
</p>
</div>
<div
class="bg-white rounded shadow p-5"
classList={{ hidden: items().length < 1 }}
>
<canvas ref={canvas} style={{ "max-height": "400px" }}></canvas>
<div class="text-sm text-center" style={{ "font-family": "Arial" }}>
Jam Ke-
</div>
</div>
<div class="bg-white rounded shadow p-5">
<Table
class="my-5"
headers={[
"Tanggal",
"Waktu",
"Jam Ke-",
"Kadar Gas",
"Suhu",
"Kelembaban",
"Status",
]}
items={items().map((item) => {
const jamKe = getLamaJam(item.created_time);
return [
getDates(item.created_time),
getTimes(item.created_time).slice(0, 8),
jamKe,
item.kadar_gas.toFixed(1) + " %",
item.suhu.toFixed(1) + " C",
item.kelembaban.toFixed(1) + " %",
item.kadar_gas > 5.28
? "Matang"
: item.kadar_gas < getKadarGasRegresi(jamKe) && jamKe >= 18
? "Gagal"
: "Menunggu",
];
})}
></Table>
</div>
</div>
);
}