mirror of
https://github.com/crocofied/CoreControl.git
synced 2025-12-17 15:36:50 +00:00
useSite merge to useSites
This commit is contained in:
parent
b4d43bc0dd
commit
3a879956ca
@ -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}
|
||||||
|
|||||||
@ -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"
|
||||||
|
|||||||
@ -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"
|
||||||
|
|||||||
@ -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;
|
||||||
|
|||||||
@ -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;
|
||||||
|
|||||||
@ -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
|
||||||
|
|||||||
@ -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;
|
|
||||||
@ -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;
|
||||||
Loading…
x
Reference in New Issue
Block a user