CoreControl/hooks/useSite.ts

64 lines
1.5 KiB
TypeScript
Raw Normal View History

2025-05-18 13:59:40 +02:00
import { useState, useEffect, useCallback } from "react";
import axios from "axios";
2025-05-18 16:09:03 +02:00
import { Site } from "@/app/types";
2025-05-18 13:59:40 +02:00
const useSite = () => {
const [site, setSite] = useState<Site>({
2025-05-18 16:09:03 +02:00
id: "",
2025-05-18 13:59:40 +02:00
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]);
2025-05-19 12:42:45 +02:00
const editSite = (site: Site): string | void => {
if (!site.id) {
return 'Site ID is required';
}
if(site.name.length < 3) {
return 'Site name must be at least 3 characters long';
}
2025-05-18 21:50:33 +02:00
axios.post('/api/sites/edit', site)
.then(() => {
2025-05-19 12:42:45 +02:00
return;
2025-05-18 21:50:33 +02:00
})
.catch(err => {
2025-05-19 12:42:45 +02:00
return err.response?.data?.error || 'An error occurred';
});
2025-05-18 21:50:33 +02:00
};
const deleteSite = (siteId: string) => {
axios.delete('/api/sites/delete', {
params: { siteId }
})
.then(() => {
setSiteId('');
})
.catch(err => {
console.error(err);
})
};
2025-05-18 13:59:40 +02:00
return {
site,
loadSite,
setSiteId,
2025-05-18 21:50:33 +02:00
editSite,
deleteSite,
2025-05-18 13:59:40 +02:00
};
};
export default useSite;