AniX/frontend/app/history/page.js
Kentai Radiquum 185e537603
frontend: add history page.
frend: make releaseOverview component
2024-04-27 11:09:46 +05:00

51 lines
1.4 KiB
JavaScript

"use client";
import { LogInNeeded } from "@/app/components/LogInNeeded/LogInNeeded";
import ReleasesOverview from "../components/ReleasesOverview/ReleasesOverview";
import { useUserStore } from "@/app/store/user-store";
import { endpoints } from "../api/config";
import { useEffect, useState } from "react";
import { getData } from "../api/api-utils";
export default function History() {
const userStore = useUserStore();
const [releases, setReleases] = useState();
const [page, setPage] = useState(0);
async function fetchData(page = 0) {
if (userStore.token) {
const url = `${endpoints.user.history}?page=${page}&token=${userStore.token}`;
const data = await getData(url);
// Handle initial load (page 0) or subsequent pagination
if (page === 0) {
setReleases(data.content);
} else {
setReleases([...releases, ...data.content]);
}
}
}
useEffect(() => {
fetchData();
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [userStore]);
useEffect(() => {
if (releases) {
fetchData(page); // Use fetchData for pagination
}
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [page]);
return (
<>
{!userStore.isAuth ? (
<LogInNeeded />
) : (
<ReleasesOverview page={page} setPage={setPage} releases={releases} />
)}
</>
);
}