useSite merge to useSites

This commit is contained in:
headlesdev 2025-05-20 20:23:08 +02:00
parent b4d43bc0dd
commit 3a879956ca
8 changed files with 98 additions and 111 deletions

View File

@ -4,7 +4,7 @@ import { Plus } from "lucide-react";
import AddSite from "@/components/dialogues/AddSite"; import AddSite from "@/components/dialogues/AddSite";
import Sites from "@/components/cards/Sites"; import Sites from "@/components/cards/Sites";
import Pagination from "@/components/Pagination"; import Pagination from "@/components/Pagination";
import useSites from "@/hooks/useSites"; import useSite from "@/hooks/useSites";
import SearchAndLayout from "@/components/SearchAndLayout"; import SearchAndLayout from "@/components/SearchAndLayout";
import Loading from "@/components/Loading"; import Loading from "@/components/Loading";
@ -25,7 +25,7 @@ export default function SitesPage({ username, name }: SitesPageProps) {
setItemPerPage, setItemPerPage,
loadSites, loadSites,
loading loading
} = useSites(); } = useSite();
return ( return (
<Sidebar <Sidebar
username={username} username={username}

View File

@ -1,6 +1,6 @@
"use client" "use client"
import Sidebar from "@/components/Sidebar" import Sidebar from "@/components/Sidebar"
import useSite from "@/hooks/useSite" import useSite from "@/hooks/useSites"
import { useEffect, useState } from "react" import { useEffect, useState } from "react"
import { Network } from "@/app/types" import { Network } from "@/app/types"
import Loading from "@/components/Loading" import Loading from "@/components/Loading"

View File

@ -4,7 +4,7 @@ import { useState } from "react"
import { Mail, User, Lock } from "lucide-react" import { Mail, User, Lock } from "lucide-react"
import ErrorToast from "@/components/Error" import ErrorToast from "@/components/Error"
import { useRouter } from "next/navigation" import { useRouter } from "next/navigation"
import useSite from "@/hooks/useSite" import useSite from "@/hooks/useSites"
import axios from "axios" import axios from "axios"
import useNetworks from "@/hooks/useNetworks" import useNetworks from "@/hooks/useNetworks"
import { Site } from "@/app/types" import { Site } from "@/app/types"

View File

@ -5,7 +5,7 @@ import axios from "axios";
import ErrorToast from "@/components/Error"; import ErrorToast from "@/components/Error";
import SuccessToast from "@/components/Success"; import SuccessToast from "@/components/Success";
import { Building2, MapPin, FileText } from "lucide-react"; import { Building2, MapPin, FileText } from "lucide-react";
import useSite from "@/hooks/useSite"; import useSite from "@/hooks/useSites";
interface AddSiteProps { interface AddSiteProps {
onSiteAdded?: () => void; onSiteAdded?: () => void;

View File

@ -2,7 +2,7 @@
import axios from "axios" import axios from "axios"
import { useRouter } from "next/navigation" import { useRouter } from "next/navigation"
import { Trash2, AlertTriangle } from "lucide-react"; import { Trash2, AlertTriangle } from "lucide-react";
import useSite from "@/hooks/useSite"; import useSite from "@/hooks/useSites";
interface DeleteSiteProps { interface DeleteSiteProps {
siteId: string; siteId: string;

View File

@ -5,7 +5,7 @@ import { Site } from "@/app/types"
import { PencilLine, Building2, FileText } from "lucide-react" import { PencilLine, Building2, FileText } from "lucide-react"
import ErrorToast from "@/components/Error" import ErrorToast from "@/components/Error"
import SuccessToast from "@/components/Success" import SuccessToast from "@/components/Success"
import useSite from "@/hooks/useSite" import useSite from "@/hooks/useSites"
interface EditSiteProps { interface EditSiteProps {
site: Site site: Site

View File

@ -1,94 +0,0 @@
import { useState, useEffect, useCallback } from "react";
import axios from "axios";
import { Site } from "@/app/types";
const useSite = () => {
const [site, setSite] = useState<Site>({
id: "",
name: "",
description: "",
networks: []
});
const [siteId, setSiteId] = useState("");
const [loading, setLoading] = useState(false);
const loadSite = useCallback(() => {
if (!siteId) return;
setLoading(true);
axios.get('/api/sites/get', {
params: { siteId }
}).then((response) => {
setSite(response.data.site);
setLoading(false);
});
}, [siteId]);
const updateSite = useCallback(() => {
if (!siteId) return;
axios.get('/api/sites/get', {
params: { siteId }
}).then((response) => {
setSite(response.data.site);
});
}, [siteId]);
useEffect(() => {
loadSite();
}, [loadSite]);
const editSite = (site: Site): Promise<string> | string => {
if (!site.id) {
return 'Site ID is required';
}
if(site.name.length < 3) {
return 'Site name must be at least 3 characters long';
}
return axios.post('/api/sites/edit', site)
.then(() => {
return "Site edited successfully";
})
.catch(err => {
throw err.response?.data?.error || 'An error occurred';
});
};
const addSite = (site: Site): Promise<Site> | string => {
if(site.name.length < 3) {
return 'Site name must be at least 3 characters long';
}
return axios.post('/api/sites/add', site)
.then((response) => {
return response.data.site;
})
.catch(err => {
throw err.response?.data?.error || 'An error occurred';
});
};
const deleteSite = (siteId: string) => {
axios.delete('/api/sites/delete', {
params: { siteId }
})
.then(() => {
setSiteId('');
})
.catch(err => {
console.error(err);
})
};
return {
site,
loadSite,
setSiteId,
updateSite,
editSite,
addSite,
deleteSite,
loading
};
};
export default useSite;

View File

@ -1,17 +1,90 @@
import { useState, useEffect, useCallback } from "react"; import { useState, useEffect, useCallback } from "react";
import axios from "axios"; import axios from "axios";
import { Site } from "@/app/types";
import Cookies from "js-cookie"; import Cookies from "js-cookie";
const useSites = () => { const useSite = () => {
const savedLayout = Cookies.get('sites-itemPerPage'); const [site, setSite] = useState<Site>({
const defaultLayout = savedLayout ? Number(savedLayout) : 5; id: "",
name: "",
const [sites, setSites] = useState([]); description: "",
networks: []
});
const [siteId, setSiteId] = useState("");
const [loading, setLoading] = useState(false);
const [currentPage, setCurrentPage] = useState(1); const [currentPage, setCurrentPage] = useState(1);
const [itemPerPage, setItemPerPage] = useState(defaultLayout); const [itemPerPage, setItemPerPage] = useState(5);
const [total, setTotal] = useState(0); const [total, setTotal] = useState(0);
const [search, setSearch] = useState(""); const [search, setSearch] = useState("");
const [loading, setLoading] = useState(false); const [sites, setSites] = useState([]);
const loadSite = useCallback(() => {
if (!siteId) return;
setLoading(true);
axios.get('/api/sites/get', {
params: { siteId }
}).then((response) => {
setSite(response.data.site);
setLoading(false);
});
}, [siteId]);
const updateSite = useCallback(() => {
if (!siteId) return;
axios.get('/api/sites/get', {
params: { siteId }
}).then((response) => {
setSite(response.data.site);
});
}, [siteId]);
useEffect(() => {
loadSite();
}, [loadSite]);
const editSite = (site: Site): Promise<string> | string => {
if (!site.id) {
return 'Site ID is required';
}
if(site.name.length < 3) {
return 'Site name must be at least 3 characters long';
}
return axios.post('/api/sites/edit', site)
.then(() => {
return "Site edited successfully";
})
.catch(err => {
throw err.response?.data?.error || 'An error occurred';
});
};
const addSite = (site: Site): Promise<Site> | string => {
if(site.name.length < 3) {
return 'Site name must be at least 3 characters long';
}
return axios.post('/api/sites/add', site)
.then((response) => {
return response.data.site;
})
.catch(err => {
throw err.response?.data?.error || 'An error occurred';
});
};
const deleteSite = (siteId: string) => {
axios.delete('/api/sites/delete', {
params: { siteId }
})
.then(() => {
setSiteId('');
})
.catch(err => {
console.error(err);
})
};
const loadSites = useCallback(() => { const loadSites = useCallback(() => {
setLoading(true); setLoading(true);
@ -35,7 +108,16 @@ const useSites = () => {
const handlePageChange = (page: number) => setCurrentPage(page); const handlePageChange = (page: number) => setCurrentPage(page);
return { return {
site,
loadSite,
setSiteId,
updateSite,
editSite,
addSite,
deleteSite,
loading,
sites, sites,
currentPage, currentPage,
itemPerPage, itemPerPage,
@ -44,9 +126,8 @@ const useSites = () => {
setSearch, setSearch,
handlePageChange, handlePageChange,
setItemPerPage, setItemPerPage,
loadSites, loadSites
loading
}; };
}; };
export default useSites; export default useSite;