CoreControl/hooks/useSite.ts
2025-05-18 15:41:20 +02:00

48 lines
927 B
TypeScript

import { useState, useEffect, useCallback } from "react";
import axios from "axios";
interface Network {
id?: number;
name: string;
ipv4Subnet?: string;
ipv6Subnet?: string;
gateway?: string;
}
interface Site {
id: number;
name: string;
description: string;
networks: Network[];
}
const useSite = () => {
const [site, setSite] = useState<Site>({
id: 0,
name: "",
description: "",
networks: []
});
const [siteId, setSiteId] = useState("");
const loadSite = useCallback(() => {
if (!siteId) return;
axios.get('/api/sites/get', {
params: { siteId }
}).then((response) => {
setSite(response.data.site);
});
}, [siteId]);
useEffect(() => {
loadSite();
}, [loadSite]);
return {
site,
loadSite,
setSiteId,
};
};
export default useSite;