Files
Mav-Mobile-UI/src/hooks/useCameraWifiandModem.ts

105 lines
3.1 KiB
TypeScript
Raw Normal View History

2025-10-02 22:53:38 +01:00
import { useQuery, useMutation } from "@tanstack/react-query";
import { CAM_BASE } from "../utils/config";
import type { ModemConfig, WifiConfig } from "../types/types";
import { useEffect } from "react";
import { toast } from "sonner";
const camBase = import.meta.env.MODE !== "development" ? CAM_BASE : "";
2025-10-02 22:53:38 +01:00
const getWiFiSettings = async () => {
const response = await fetch(`${camBase}/api/fetch-config?id=ModemAndWifiManager-wifi`, {
signal: AbortSignal.timeout(500),
});
2025-10-02 22:53:38 +01:00
if (!response.ok) {
throw new Error("Cannot fetch Wifi settings");
}
return response.json();
};
const updateWifiSettings = async (wifiConfig: WifiConfig) => {
const response = await fetch(`${camBase}/api/update-config?id=ModemAndWifiManager-wifi`, {
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify(wifiConfig),
});
2025-10-02 22:53:38 +01:00
if (!response.ok) {
throw new Error("Cannot update wifi settings");
}
return response.json();
};
const getModemSettings = async () => {
const response = await fetch(`${camBase}/api/fetch-config?id=ModemAndWifiManager-modem`, {
signal: AbortSignal.timeout(500),
});
if (!response.ok) {
throw new Error("Cannot fetch modem settings");
}
return response.json();
};
const updateModemSettings = async (modemConfig: ModemConfig) => {
const response = await fetch(`${camBase}/api/update-config?id=ModemAndWifiManager-modem`, {
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify(modemConfig),
});
if (!response.ok) {
throw new Error("cannot update modem settings");
}
return response.json();
};
2025-10-02 22:53:38 +01:00
export const useWifiAndModem = () => {
const wifiQuery = useQuery({
queryKey: ["getWifiSettings"],
queryFn: getWiFiSettings,
});
const wifiMutation = useMutation({
mutationKey: ["updateWifiSettings"],
mutationFn: (wifiConfig: WifiConfig) => updateWifiSettings(wifiConfig),
onError: (error) => {
toast.error("Failed to update WiFi settings", { id: "wiFiSettings" });
console.error(error);
},
onSuccess: () => {
toast.success("WiFi settings updated successfully", {
id: "wiFiSettings",
});
},
});
const modemQuery = useQuery({
queryKey: ["getModemSettings"],
queryFn: getModemSettings,
});
const modemMutation = useMutation({
mutationKey: ["updateModemSettings"],
mutationFn: (modemConfig: ModemConfig) => updateModemSettings(modemConfig),
onError: (error) => {
toast.error("Failed to update Modem settings", { id: "modemSettings" });
console.error(error);
},
onSuccess: () => {
toast.success("Modem settings updated successfully", {
id: "modemSettings",
});
},
2025-10-02 22:53:38 +01:00
});
useEffect(() => {
if (wifiQuery.isError) toast.error("Cannot get WiFi settings", { id: "wiFiSettings" });
}, [wifiQuery?.error?.message, wifiQuery.isError]);
useEffect(() => {
if (modemQuery.isError) toast.error("Cannot get Modem settings", { id: "modemSettings" });
}, [modemQuery?.error?.message, modemQuery.isError]);
2025-10-02 22:53:38 +01:00
return {
wifiQuery,
wifiMutation,
modemQuery,
modemMutation,
2025-10-02 22:53:38 +01:00
};
};