From f91379ae5f202f84420ff7f83f1b1350cd1ebda3 Mon Sep 17 00:00:00 2001 From: Muhammad Izza Alfiansyah Date: Sat, 11 May 2024 09:26:25 +0700 Subject: [PATCH] add start fermentation to website --- microdebugging/microdebugging.ino | 554 ++++++++++++++++-------------- website/src/App.tsx | 22 +- website/src/pages/Index.tsx | 121 ++++--- website/src/pages/Pengaturan.tsx | 8 +- website/src/types/Pengaturan.ts | 1 + 5 files changed, 392 insertions(+), 314 deletions(-) diff --git a/microdebugging/microdebugging.ino b/microdebugging/microdebugging.ino index 59fe61e..4db9287 100644 --- a/microdebugging/microdebugging.ino +++ b/microdebugging/microdebugging.ino @@ -1,18 +1,19 @@ -// // #include -// #include -// #include +// #include +#include +#include // #include -// #include -// #include +#include +#include // #include // #include +// #include -// #define BOARD "ESP-32" -// #define MQPIN 34 -// #define DHTPIN 4 -// #define LAMPPIN 26 -// #define FANPIN 25 -// #define BUZZERPIN 23 +#define BOARD "ESP-32" +#define MQPIN 34 +#define DHTPIN 4 +#define LAMPPIN 26 +#define FANPIN 25 +#define BUZZERPIN 23 // #define SUPABASE_URL "https://oxmfbobxmqldgthethlz.supabase.co" // #define SUPABASE_ANON_KEY "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6Im94bWZib2J4bXFsZGd0aGV0aGx6Iiwicm9sZSI6ImFub24iLCJpYXQiOjE3MDgwNjQ1NDksImV4cCI6MjAyMzY0MDU0OX0.pTDI9CsiN8wthOWhHjM1dONrRP_Hd7BcbwfKgeKGhtU" @@ -20,270 +21,297 @@ // #define WIFI_SSID "Vivo Y21c" // #define WIFI_PASSWORD "12346789" -// // Supabase db; -// LiquidCrystal_I2C lcd(0x27, 16, 2); -// DHT dht(DHTPIN, 22); -// // WiFiUDP ntpUDP; -// // NTPClient timeClient(ntpUDP, "pool.ntp.org", 3600 * 7, 60000); // GMT +7 +// Supabase db; +LiquidCrystal_I2C lcd(0x27, 16, 2); +DHT dht(DHTPIN, 22); +// WiFiUDP ntpUDP; +// NTPClient timeClient(ntpUDP, "pool.ntp.org", 3600 * 7, 60000); // GMT +7 -// float suhu; -// float kelembaban; -// float persentaseKadarGas; -// bool pengujian; -// float kadarGasVoltase; -// // JSONVar dataPengujian; +float suhu; +float kelembaban; +float persentaseKadarGas; +bool pengujian; +float kadarGasVoltase; +String status = "Menunggu"; +JSONVar dataPengujian; -// void setup(){ -// pinMode(MQPIN, INPUT); -// pinMode(LAMPPIN, OUTPUT); -// pinMode(FANPIN, OUTPUT); -// pinMode(BUZZERPIN, OUTPUT); +void setup(){ + pinMode(MQPIN, INPUT); + pinMode(LAMPPIN, OUTPUT); + pinMode(FANPIN, OUTPUT); + pinMode(BUZZERPIN, OUTPUT); -// digitalWrite(LAMPPIN, HIGH); -// digitalWrite(FANPIN, HIGH); + digitalWrite(LAMPPIN, HIGH); + digitalWrite(FANPIN, HIGH); + digitalWrite(BUZZERPIN, HIGH); -// Serial.begin(115200); + Serial.begin(115200); -// // inisialisasi LCD -// lcd.init(); -// lcd.backlight(); + // inisialisasi LCD + lcd.init(); + lcd.backlight(); -// lcd.setCursor(0, 0); -// lcd.print("Memuat.........."); + lcd.setCursor(0, 0); + lcd.print("Memuat.........."); -// // inisialisasi DHT22 -// dht.begin(); + // inisialisasi DHT22 + dht.begin(); -// // inisialisasi WiFi -// // Serial.print("Menghubungkan ke WiFi"); -// // WiFi.begin(WIFI_SSID, WIFI_PASSWORD); + // inisialisasi WiFi + // Serial.print("Menghubungkan ke WiFi"); + // WiFi.begin(WIFI_SSID, WIFI_PASSWORD); -// delay(20000); + delay(20000); -// // menampilkan gagal terhubung ke jaringan pada LCD -// // if (WiFi.status() != WL_CONNECTED) { -// // lcd.setCursor(0, 0); -// // lcd.print("Gagal terhubung"); -// // lcd.setCursor(0, 1); -// // lcd.print("ke jaringan!"); -// // } + // menampilkan gagal terhubung ke jaringan pada LCD + // if (WiFi.status() != WL_CONNECTED) { + // lcd.setCursor(0, 0); + // lcd.print("Gagal terhubung"); + // lcd.setCursor(0, 1); + // lcd.print("ke jaringan!"); + // } -// // inisialisasi waktu -// // timeClient.begin(); + // inisialisasi waktu + // timeClient.begin(); -// // inisialisasi supabase -// // db.begin(SUPABASE_URL, SUPABASE_ANON_KEY); + // inisialisasi supabase + // db.begin(SUPABASE_URL, SUPABASE_ANON_KEY); -// // getDataPengujian(); -// } - -// void loop(){ -// // timeClient.update(); - -// // mendapatkan nilai kadar gas -// float kadarGas = getKadarGas(); -// kadarGasVoltase = kadarGas / 4095.0 * 3.3; -// persentaseKadarGas = getPersentaseKadarGas(kadarGasVoltase); - -// // menampilkan kadar gas pada LCD -// lcd.clear(); -// lcd.setCursor(0, 0); -// lcd.print("G : "); -// lcd.print(kadarGas); -// lcd.setCursor(0,1); -// lcd.print("PG : "); -// lcd.print(persentaseKadarGas, 1); -// lcd.print(" %"); - -// delay(2000); - -// // membaca nilai suhu dan kelembaban -// suhu = dht.readTemperature(); -// kelembaban = dht.readHumidity(); - -// // menampilkan suhu dan kelembaban pada LCD -// lcd.clear(); -// lcd.setCursor(0, 0); -// lcd.print("S : "); -// lcd.print(suhu, 1); -// lcd.print(" C"); -// lcd.setCursor(0, 1); -// lcd.print("K : "); -// lcd.print(kelembaban, 1); -// lcd.print(" %"); - -// // menyalakan lampu jika suhu di bawah 30 -// if (suhu <= 30) { -// digitalWrite(LAMPPIN, LOW); -// } else { -// digitalWrite(LAMPPIN, HIGH); -// } - -// // menyalakan kipas jika suhu di atas 40 -// if (suhu >= 40) { -// digitalWrite(FANPIN, LOW); -// } else { -// digitalWrite(FANPIN, HIGH); -// } - -// // menentukan data masuk ke pengujian atau tidak berdasarkan jarak jam -// // long unsigned epochTimeNow = timeClient.getEpochTime(); - -// // if (dataPengujian.length() > 0) { -// // JSONVar dataPengujianTerakhir = dataPengujian[dataPengujian.length() - 1]; -// // int created_time = dataPengujianTerakhir["created_time"]; - -// // int epochTimeDiff = epochTimeNow - created_time; -// // int jam = epochTimeDiff / 3600; // 1 jam = 3600 detik; - -// // if (jam >= 6) { -// // pengujian = true; -// // } else { -// // pengujian = false; -// // } -// // } - -// getDebugging(); - -// // insertKondisiTapai(); -// // cekKematangan(); - -// delay(2000); -// lcd.clear(); -// } - -// void getDebugging() { -// Serial.println("Voltase Kadar Gas : " + String(kadarGasVoltase)); -// Serial.println("Persentase Kadar Gas : " + String(persentaseKadarGas) + " %"); -// Serial.println("Suhu : " + String(suhu) + " C"); -// Serial.println("Kelembaban : " + String(kelembaban) + " %"); -// } - -// // mendapatkana nilai rata-rata kadar gas dari 100 data sampel yang diambil -// float getKadarGas() { -// int total = 100; -// int valueTotal = 0; - -// for (int i = 0; i < total; i++) { -// int value = analogRead(MQPIN); -// valueTotal = valueTotal + value; -// } - -// float valueAvg = valueTotal / total; - -// return valueAvg; -// } - -// // konversi tegangan ke persen berdasarkan rumus yang telah ditentukan -// float getPersentaseKadarGas(float voltase) { -// float persentase = 0.2043 * pow(voltase, 2) + 0.0611 * voltase - 0.0249; -// float hasil = constrain(persentase * 100, 0, 100); - -// return hasil; -// } - -// // // menyimpan kondisi tapai pada database -// // void insertKondisiTapai() { -// // JSONVar req; - -// // req["suhu"] = (float) suhu; -// // req["kelembaban"] = (float) kelembaban; -// // req["kadar_gas"] = (float) persentaseKadarGas; -// // req["pengujian"] = (bool) pengujian; -// // req["created_time"] = (int) timeClient.getEpochTime(); - -// // String json = JSON.stringify(req); -// // db.insert("kondisi_tapai", json, false); - -// // if (pengujian == true) { -// // getDataPengujian(); -// // } -// // } - -// // // melakukan cek kematangan -// // void cekKematangan() { -// // String dataHistori = db.from("histori_fermentasi").select("*").order("created_at", "desc", true).limit(1).doSelect(); -// // JSONVar dataHistoriTerakhir = JSON.parse(dataHistori)[0]; - -// // if (dataHistoriTerakhir["selesai"] == false) { -// // digitalWrite(BUZZERPIN, HIGH); -// // } else { -// // digitalWrite(BUZZERPIN, LOW); - -// // if (persentaseKadarGas >= 5.3 && kelembaban >= 93) { -// // String dataAWalJson = db.from("kondisi_tapai").select("*").order("created_at", "asc", true).limit(1).doSelect(); -// // String dataAkhirJson = db.from("kondisi_tapai").select("*").order("created_at", "desc", true).limit(1).doSelect(); - -// // JSONVar dataAwal = JSON.parse(dataAwalJson); -// // JSONVar dataAkhir = JSON.parse(dataAkhirJson); - -// // JSONVar req; -// // req["berhasil"] = true; -// // req["waktu_awal"] = dataAwal[0]["created_time"]; -// // req["waktu_akhir"] = dataAkhir[0]["created_time"] - -// // String json = JSON.stringify(req); - -// // db.insert("histori_fermentasi", json, false); -// // } -// // } -// // } - -// // // mengambil data pengujian -// // void getDataPengujian() { -// // String json = db.from("kondisi_tapai").select("*").eq("pengujian", "TRUE").order("created_at", "asc", true).doSelect(); -// // dataPengujian = JSON.parse(json); -// // } - -/* - Rui Santos - Complete project details at https://RandomNerdTutorials.com/telegram-control-esp32-esp8266-nodemcu-outputs/ - - Project created using Brian Lough's Universal Telegram Bot Library: https://github.com/witnessmenow/Universal-Arduino-Telegram-Bot - Example based on the Universal Arduino Telegram Bot Library: https://github.com/witnessmenow/Universal-Arduino-Telegram-Bot/blob/master/examples/ESP8266/FlashLED/FlashLED.ino -*/ - -#include -#include - -#define WEB_URL "http://localhost:5173"; - -const char* ssid = "Vivo Y21c"; -const char* password = "12346789"; - -// Note : -// username : @username or phonenumber (Indonesia +62, Example: "+62897461238") -// You need to authorize CallMeBot to contact you using this link : https://api2.callmebot.com/txt/login.php. -// Or alternatively, you can start the bot sending /start to @CallMeBot_txtbot. -String username = "+6281231921351"; -String text = "Hello from ESP32"; - -void setup() { - Serial.begin(115200); - - WiFi.begin(ssid, password); - Serial.println("Connecting"); - while(WiFi.status() != WL_CONNECTED) { - delay(500); - Serial.print("."); - } - Serial.println(""); - Serial.print("Connected to WiFi network with IP Address: "); - Serial.println(WiFi.localIP()); - - // Telegram Call - String text; - if (true) { - text = "Fermentasi tapai berhasil dan sudah matang."; - } else { - text = "Fermentasi tapai gagal."; - } - - text = text + " Lihat selengkapnya di " + WEB_URL + "."; - Callmebot.telegramCall(username, text); - Serial.println(Callmebot.debug()); + // getDataPengujian(); } -void loop() { - -} \ No newline at end of file +void loop(){ + // timeClient.update(); + + // mendapatkan nilai kadar gas + float kadarGas = getKadarGas(); + kadarGasVoltase = kadarGas / 4095.0 * 3.3; + persentaseKadarGas = getPersentaseKadarGas(kadarGasVoltase); + + // menampilkan kadar gas pada LCD + lcd.clear(); + lcd.setCursor(0, 0); + lcd.print("G : "); + lcd.print(persentaseKadarGas, 1); + lcd.print("%-"); + lcd.print(kadarGasVoltase, 2); + lcd.print("V"); + lcd.setCursor(0,1); + lcd.print("H : "); + lcd.print(status); + + delay(2000); + + // membaca nilai suhu dan kelembaban + suhu = dht.readTemperature(); + kelembaban = dht.readHumidity(); + + if (suhu != 25.5 && kelembaban != 25.5) { + // menampilkan suhu dan kelembaban pada LCD + lcd.clear(); + lcd.setCursor(0, 0); + lcd.print("S : "); + lcd.print(suhu, 1); + lcd.print(" C"); + lcd.setCursor(0, 1); + lcd.print("K : "); + lcd.print(kelembaban, 1); + lcd.print(" %"); + + // menyalakan lampu jika suhu di bawah 30 + if (suhu <= 30) { + digitalWrite(LAMPPIN, LOW); + } else { + digitalWrite(LAMPPIN, HIGH); + } + + // menyalakan kipas jika suhu di atas 40 + if (suhu >= 40) { + digitalWrite(FANPIN, LOW); + } else { + digitalWrite(FANPIN, HIGH); + } + + // menentukan data masuk ke pengujian atau tidak berdasarkan jarak jam + // long unsigned epochTimeNow = timeClient.getEpochTime(); + + // if (dataPengujian.length() > 0) { + // JSONVar dataPengujianTerakhir = dataPengujian[dataPengujian.length() - 1]; + // int created_time = dataPengujianTerakhir["created_time"]; + + // int epochTimeDiff = epochTimeNow - created_time; + // int jam = epochTimeDiff / 3600; // 1 jam = 3600 detik; + + // if (jam >= 6) { + // pengujian = true; + // } else { + // pengujian = false; + // } + // } + + getDebugging(); + + // String dataHistoriJson = db.from("histori_fermentasi").select("*").order("created_at", "desc", true).limit(1).doSelect(); + // JSONVar dataHistori = JSON.parse(dataHistoriJson); + // bool statusHistoriTerakhir = dataHistori[0]["selesai"]; + + // if (statusHistoriTerakhir == false) { + // digitalWrite(BUZZERPIN, LOW); + + // bool historiTerakhirBerhasil = (bool) dataHistori[0]["berhasil"]; + + // if (historiTerakhirBerhasil) { + // status = "Matang"; + // } else { + // status = "Gagal"; + // } + // } else { + // digitalWrite(BUZZERPIN, HIGH); + // cekKematangan(); + // cekKegagalan(); + // insertKondisiTapai(); + // } + + delay(2000); + lcd.clear(); + } +} + +void getDebugging() { + Serial.println("Voltase Kadar Gas : " + String(kadarGasVoltase)); + Serial.println("Persentase Kadar Gas : " + String(persentaseKadarGas) + " %"); + Serial.println("Suhu : " + String(suhu) + " C"); + Serial.println("Kelembaban : " + String(kelembaban) + " %"); +} + +// mendapatkana nilai rata-rata kadar gas dari 100 data sampel yang diambil +float getKadarGas() { + int total = 100; + int valueTotal = 0; + + for (int i = 0; i < total; i++) { + int value = analogRead(MQPIN); + valueTotal = valueTotal + value; + } + + float valueAvg = valueTotal / total; + + return valueAvg; +} + +// konversi tegangan ke persen berdasarkan rumus yang telah ditentukan +float getPersentaseKadarGas(float voltase) { + float persentase = 0.2043 * pow(voltase, 2.0) + 0.0611 * voltase - 0.0249; + float hasil = constrain(persentase * 100, 0, 100); + + return hasil; +} + +// void callUser(bool matang = true) { +// String pengaturanJson = db.from("pengaturan").select("*").limit(1).doSelect(); +// JSONVar pengaturan = JSON.parse(pengaturanJson); +// String web_url = pengaturan[0]["web_url"]; + +// String text; +// if (matang == true) { +// text = "Fermentasi tapai berhasil dan sudah matang. "; +// } else { +// text = "Fermentasi tapai gagal. "; +// } + +// text = text + "Lihat selengkapnya di " + web_url + "."; + +// Callmebot.telegramCall(pengaturan[0]["telepon"], text, "id-ID-Standard-B"); +// Serial.println(Callmebot.debug()); +// } + +// // menyimpan kondisi tapai pada database +// void insertKondisiTapai() { +// JSONVar req; + +// req["suhu"] = (float) suhu; +// req["kelembaban"] = (float) kelembaban; +// req["kadar_gas"] = (float) persentaseKadarGas; +// req["pengujian"] = (bool) pengujian; +// req["created_time"] = (int) timeClient.getEpochTime(); + +// String json = JSON.stringify(req); +// db.insert("kondisi_tapai", json, false); + +// if (pengujian == true) { +// getDataPengujian(); +// } +// } + +// // melakukan cek kematangan +// void cekKematangan() { +// if (persentaseKadarGas >= 5.28) { +// status = "Matang"; + +// String dataAwalJson = db.from("kondisi_tapai").select("*").order("created_time", "asc", true).limit(1).doSelect(); +// String dataAkhirJson = db.from("kondisi_tapai").select("*").order("created_time", "desc", true).limit(1).doSelect(); + +// JSONVar dataAwal = JSON.parse(dataAwalJson); +// JSONVar dataAkhir = JSON.parse(dataAkhirJson); + +// JSONVar req; +// req["berhasil"] = true; +// req["waktu_awal"] = (int) dataAwal[0]["created_time"]; +// req["waktu_akhir"] = (int) dataAkhir[0]["created_time"]; + +// String json = JSON.stringify(req); + +// callUser(true); +// db.insert("histori_fermentasi", json, false); + +// pengujian = true; +// } +// } + +// // mengecek kegagalan +// void cekKegagalan() { +// JSONVar dataPengujianAwal = dataPengujian[0]; +// int epochTimeAwal = (int) dataPengujianAwal["created_time"]; + +// for (int i = 0; i < dataPengujian.length(); i++) { +// int epochTime = (int) dataPengujian[i]["created_time"]; +// int epochTimeDiff = epochTime - epochTimeAwal; +// int lamaJam = epochTimeDiff / 3600; + +// float kadarGas = (double) dataPengujian[i]["kadar_gas"]; +// float regresiKadarGas = 0.0025 * pow(lamaJam, 2.0) - 0.0397 * lamaJam - 0.1222; +// float nilaiPerempat = regresiKadarGas / 4.0; + +// if (lamaJam > 12) { +// if (kadarGas > (regresiKadarGas + nilaiPerempat) || kadarGas < (regresiKadarGas - nilaiPerempat)) { +// status = "Gagal"; +// } +// } +// } + +// if (status == "Gagal") { +// String dataAwalJson = db.from("kondisi_tapai").select("*").order("created_time", "asc", true).limit(1).doSelect(); +// String dataAkhirJson = db.from("kondisi_tapai").select("*").order("created_time", "desc", true).limit(1).doSelect(); + +// JSONVar dataAwal = JSON.parse(dataAwalJson); +// JSONVar dataAkhir = JSON.parse(dataAkhirJson); + +// JSONVar req; +// req["berhasil"] = false; +// req["waktu_awal"] = (int) dataAwal[0]["created_time"]; +// req["waktu_akhir"] = (int) dataAkhir[0]["created_time"]; + +// String json = JSON.stringify(req); + +// callUser(false); +// db.insert("histori_fermentasi", json, false); + +// pengujian = true; +// } +// } + +// // mengambil data pengujian +// void getDataPengujian() { +// String json = db.from("kondisi_tapai").select("*").eq("pengujian", "TRUE").order("created_time", "asc", true).doSelect(); +// dataPengujian = JSON.parse(json); +// } \ No newline at end of file diff --git a/website/src/App.tsx b/website/src/App.tsx index a3c0755..bdfd59f 100644 --- a/website/src/App.tsx +++ b/website/src/App.tsx @@ -1,4 +1,4 @@ -import { A, useLocation } from "@solidjs/router"; +import { A, useLocation, useNavigate } from "@solidjs/router"; import { createSignal, For, JSX, Match, onMount, Switch } from "solid-js"; import SettingIcon from "./icons/SettingIcon"; import HomeIcon from "./icons/HomeIcon"; @@ -6,6 +6,7 @@ import ArchiveIcon from "./icons/ArchiveIcon"; import ClockIcon from "./icons/ClockIcon"; import supabase from "./utils/supabase"; import { Histori } from "./types/Histori"; +import { Pengaturan } from "./types/Pengaturan"; export default function (props: JSX.HTMLAttributes) { const menus = [ @@ -34,6 +35,7 @@ export default function (props: JSX.HTMLAttributes) { const [lastHistori, setLastHistori] = createSignal(null); const location = useLocation(); + const navigate = useNavigate(); const getLastHistori = async () => { const { data } = await supabase @@ -95,7 +97,7 @@ export default function (props: JSX.HTMLAttributes) { .order("created_time", { ascending: false }) .limit(1); - if (lastHistori()?.selesai) { + if (lastHistori()?.selesai != false) { if (lastData1![0].created_time == lastData2![0].created_time) { alert("Device offline!"); } @@ -104,9 +106,23 @@ export default function (props: JSX.HTMLAttributes) { await checkStatusDevice(); }; + const checkPengaturan = async () => { + const { data } = await supabase.from("pengaturan").select("*").limit(1); + if (data) { + const item: Pengaturan = data[0]; + + if (!item.running) { + if (location.pathname != "/") { + navigate("/"); + } + } + } + }; + onMount(async () => { + await checkPengaturan(); await getLastHistori(); - await checkStatusDevice(); + // await checkStatusDevice(); }); return ( diff --git a/website/src/pages/Index.tsx b/website/src/pages/Index.tsx index 558df74..2368ee4 100644 --- a/website/src/pages/Index.tsx +++ b/website/src/pages/Index.tsx @@ -5,6 +5,7 @@ import { Chart, registerables } from "chart.js"; import supabase from "../utils/supabase"; import { getTimes } from "../utils/dates"; import { Histori } from "../types/Histori"; +import { Pengaturan } from "../types/Pengaturan"; export default function () { let canvas: any; @@ -15,6 +16,7 @@ export default function () { const [timeStamps, setTimeStamps] = createSignal([]); const [lastHistori, setLastHistori] = createSignal(null); + const [pengaturan, setPengaturan] = createSignal(null); const getLastHistori = async () => { const { data } = await supabase @@ -127,64 +129,95 @@ export default function () { }, 4000); }; + const getPengaturan = async () => { + const { data } = await supabase.from("pengaturan").select("*").limit(1); + + if (data) { + setPengaturan(data[0]); + } + }; + + const startFermentasi = async () => { + await supabase.from("pengaturan").update({ running: true }).eq("id", 1); + window.location.reload(); + }; + onMount(async () => { + await getPengaturan(); Chart.register(...registerables); await renderChart(); await getLastHistori(); }); return ( -
- -
Data tidak terdeteksi
-
- -
-
-
0 ? "" : "hidden")}> -
-
-
- {lastHistori()?.selesai == false - ? lastHistori()?.berhasil - ? "Matang" - : "Gagal" - : "Menunggu"} -
+ +
+
-
-
- -
- {suhu().toString().slice(0, 4)} °C +
+ } + > +
+ +
Data tidak terdeteksi
+
+ +
+
+
0 ? "" : "hidden")}> +
+
+
+ {lastHistori()?.selesai == false + ? lastHistori()?.berhasil + ? "Matang" + : "Gagal" + : "Menunggu"}
-
- -
- {kelembaban().toString().slice(0, 4)} % +
+
+ +
+ {suhu().toString().slice(0, 4)} °C +
+
+
+ +
+ {kelembaban().toString().slice(0, 4)} % +
-
-
-
Grafik Kadar Gas
- +
+
Grafik Kadar Gas
+ +
-
+ ); } diff --git a/website/src/pages/Pengaturan.tsx b/website/src/pages/Pengaturan.tsx index f97a2fb..8fc727c 100644 --- a/website/src/pages/Pengaturan.tsx +++ b/website/src/pages/Pengaturan.tsx @@ -38,7 +38,7 @@ export default function () { Kontak digunakan untuk mengirimkan notifikasi sistem kepada pemilik.

-
+ {/*
Email
handleReqChange("email", e.target.value)} /> -
+
*/}
-
No. Whatsapp
+
Username / Nomor Telegram
handleReqChange("telepon", e.target.value)} /> diff --git a/website/src/types/Pengaturan.ts b/website/src/types/Pengaturan.ts index ff515f1..ff0a5b4 100644 --- a/website/src/types/Pengaturan.ts +++ b/website/src/types/Pengaturan.ts @@ -4,4 +4,5 @@ export interface Pengaturan { telepon: string; suhu_min: number; suhu_max: number; + running: boolean; } \ No newline at end of file