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([]); 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 (
Analisis Data

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.

Jam Ke-
{ 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", ]; })} >
); }