"use client"; import useSWR from "swr"; import { ReleaseCourusel } from "#/components/ReleaseCourusel/ReleaseCourusel"; import { Spinner } from "#/components/Spinner/Spinner"; import { useUserStore } from "#/store/auth"; import { usePreferencesStore } from "#/store/preferences"; import { BookmarksList, useSWRfetcher } from "#/api/utils"; import { ENDPOINTS } from "#/api/config"; import { useRouter } from "next/navigation"; import { useEffect } from "react"; export function BookmarksPage(props: { profile_id?: number }) { const token = useUserStore((state) => state.token); const authState = useUserStore((state) => state.state); const router = useRouter(); const preferenceStore = usePreferencesStore(); useEffect(() => { if (preferenceStore.params.skipToCategory.enabled) { if (props.profile_id) { router.push( `/profile/${props.profile_id}/bookmarks/${preferenceStore.params.skipToCategory.bookmarksCategory}` ); } else { router.push( `/bookmarks/${preferenceStore.params.skipToCategory.bookmarksCategory}` ); } } // eslint-disable-next-line react-hooks/exhaustive-deps }, []); function useFetchReleases(listName: string) { let url: string; if (preferenceStore.params.skipToCategory.enabled) { return [null, null]; } if (props.profile_id) { url = `${ENDPOINTS.user.bookmark}/all/${props.profile_id}/${BookmarksList[listName]}/0?sort=1`; if (token) { url += `&token=${token}`; } } else { if (token) { url = `${ENDPOINTS.user.bookmark}/all/${BookmarksList[listName]}/0?sort=1&token=${token}`; } } // eslint-disable-next-line react-hooks/rules-of-hooks const { data, error } = useSWR(url, useSWRfetcher); return [data, error]; } useEffect(() => { if (authState === "finished" && !token && !props.profile_id) { router.push("/login?redirect=/bookmarks"); } // eslint-disable-next-line react-hooks/exhaustive-deps }, [authState, token]); const [watchingData, watchingError] = useFetchReleases("watching"); const [plannedData, plannedError] = useFetchReleases("planned"); const [watchedData, watchedError] = useFetchReleases("watched"); const [delayedData, delayedError] = useFetchReleases("delayed"); const [abandonedData, abandonedError] = useFetchReleases("abandoned"); return ( <> {authState === "loading" && (!watchingData || !plannedData || !watchedData || !delayedData || !abandonedData) && (
)} {watchingData && watchingData.content && watchingData.content.length > 0 && ( )} {plannedData && plannedData.content && plannedData.content.length > 0 && ( )} {watchedData && watchedData.content && watchedData.content.length > 0 && ( )} {delayedData && delayedData.content && delayedData.content.length > 0 && ( )} {abandonedData && abandonedData.content && abandonedData.content.length > 0 && ( )} {(watchingError || plannedError || watchedError || delayedError || abandonedError) && (

Ошибка

Произошла ошибка при загрузке закладок. Попробуйте обновить страницу или зайдите позже.

)} ); }