mirror of
https://github.com/Radiquum/AniX.git
synced 2025-07-02 10:28:42 +05:00
frontend: reduce code in index page.js file
This commit is contained in:
parent
227bada365
commit
732799703d
1 changed files with 47 additions and 47 deletions
|
@ -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">
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue