frontend: reduce code in index page.js file

This commit is contained in:
Kentai Radiquum 2024-04-21 01:32:27 +05:00
parent 227bada365
commit 732799703d
Signed by: Radiquum
GPG key ID: 858E8EE696525EED

View file

@ -5,7 +5,6 @@ import { endpoints } from "./api/config";
import { useEffect, useState, useCallback } from "react"; import { useEffect, useState, useCallback } from "react";
import { usePathname, useRouter } from "next/navigation"; import { usePathname, useRouter } from "next/navigation";
import { CardList } from "./components/CardList/CardList"; import { CardList } from "./components/CardList/CardList";
import { useSearchParams } from "next/navigation"; import { useSearchParams } from "next/navigation";
export default function Home() { export default function Home() {
@ -27,71 +26,72 @@ export default function Home() {
[searchParams] [searchParams]
); );
// set list on initial page load
useEffect(() => { useEffect(() => {
setList(searchParams.get("list") || "last"); setList(searchParams.get("list") || "last");
}, []); }, []);
async function getReleases() { async function fetchData(list, page = 0) {
const data = await getData(`${endpoints.index[list]}`); const url = `${endpoints.index[list]}?page=${page}`;
setReleases(data.content); const data = await getData(url);
}
// Handle initial load (page 0) or subsequent pagination
async function getPage() { if (page === 0) {
const data = await getData(`${endpoints.index[list]}?page=${page}`); setReleases(data.content);
setReleases([...releases, ...data.content]); } else {
setReleases([...releases, ...data.content]);
}
} }
useEffect(() => { useEffect(() => {
router.push(pathname + "?" + createQueryString("list", list)); router.push(pathname + "?" + createQueryString("list", list));
setReleases(null); setReleases(null);
setPage(0); setPage(0);
if (list) { fetchData(list); // Call fetchData here
getReleases();
}
}, [list]); }, [list]);
useEffect(() => { useEffect(() => {
if (list && releases) { if (list && releases) {
getPage(); fetchData(list, page); // Use fetchData for pagination
} }
}, [page]); }, [page]);
const chips = [
{
title: "последнее",
list: "last",
},
{
title: "в эфире",
list: "ongoing",
},
{
title: "анонсировано",
list: "announce",
},
{
title: "завершено",
list: "finished",
},
];
return ( return (
<> <>
<div> <div>
<button {chips.map((item) => {
className={`chip ${list == "last" ? "fill" : ""}`} return (
onClick={() => { <button
setList("last"); className={`chip ${list == item.list ? "fill" : ""}`}
}} onClick={() => {
> setList(item.list);
<span>последнее</span> }}
</button> >
<button <span>{item.title}</span>
className={`chip ${list == "ongoing" ? "fill" : ""}`} </button>
onClick={() => { );
setList("ongoing"); })}
}}
>
<span>в эфире</span>
</button>
<button
className={`chip ${list == "announce" ? "fill" : ""}`}
onClick={() => {
setList("announce");
}}
>
<span>анонсировано</span>
</button>
<button
className={`chip ${list == "finished" ? "fill" : ""}`}
onClick={() => {
setList("finished");
}}
>
<span>завершено</span>
</button>
</div> </div>
{releases ? ( {releases ? (
<> <>
<div className="grid"> <div className="grid">