UIKit/src/hooks/useTariffs.ts

40 lines
1.3 KiB
TypeScript
Raw Normal View History

2023-06-17 14:24:12 +00:00
import { useEffect, useState } from "react";
import { makeRequest } from "../api";
import { Tariff, GetTariffsResponse } from "../model/tariff";
2023-06-17 14:27:22 +00:00
import { devlog } from "../utils";
2023-06-17 14:24:12 +00:00
export function useTariffs({ url, tariffsPerPage, apiPage, onNewTariffs, onError }: {
url: string;
tariffsPerPage: number;
apiPage: number;
onNewTariffs: (response: Tariff[]) => void;
onError: (error: Error) => void;
}) {
const [fetchState, setFetchState] = useState<"fetching" | "idle" | "all fetched">("idle");
useEffect(function fetchTickets() {
const controller = new AbortController();
setFetchState("fetching");
makeRequest<never, GetTariffsResponse>({
url,
method: "get",
useToken: true,
signal: controller.signal,
}).then((result) => {
2023-06-17 14:27:22 +00:00
devlog("GetTariffsResponse", result);
2023-06-17 14:24:12 +00:00
if (result.tariffs.length > 0) {
onNewTariffs(result.tariffs);
setFetchState("idle");
} else setFetchState("all fetched");
}).catch(error => {
2023-06-17 14:27:22 +00:00
devlog("Error fetching tariffs", error);
2023-06-17 14:24:12 +00:00
onError(error);
});
return () => controller.abort();
}, [onError, onNewTariffs, apiPage, tariffsPerPage, url]);
return fetchState;
}