import { Card, Carousel, RatingStar, Rating, Modal, Button, } from "flowbite-react"; import type { FlowbiteCarouselIndicatorsTheme, FlowbiteCarouselControlTheme, } from "flowbite-react"; import Image from "next/image"; import { unixToDate, useSWRfetcher } from "#/api/utils"; import Link from "next/link"; import { useCallback, useEffect, useState } from "react"; import { ENDPOINTS } from "#/api/config"; import useSWRInfinite from "swr/infinite"; import { Spinner } from "../Spinner/Spinner"; const CarouselIndicatorsTheme: FlowbiteCarouselIndicatorsTheme = { active: { off: "bg-gray-300/50 hover:bg-gray-400 dark:bg-gray-400/50 dark:hover:bg-gray-200", on: "bg-gray-600 dark:bg-gray-200", }, base: "h-3 w-3 rounded-full", wrapper: "absolute bottom-5 left-1/2 flex -translate-x-1/2 space-x-3", }; const CarouselControlsTheme: FlowbiteCarouselControlTheme = { base: "inline-flex h-8 w-8 items-center justify-center rounded-full bg-gray-600/30 group-hover:bg-gray-600/50 group-focus:outline-none group-focus:ring-4 group-focus:ring-gray-600 dark:bg-gray-400/30 dark:group-hover:bg-gray-400/60 dark:group-focus:ring-gray-400/70 sm:h-10 sm:w-10", icon: "h-5 w-5 text-gray-600 dark:text-gray-400 sm:h-6 sm:w-6", }; const CarouselTheme = { indicators: CarouselIndicatorsTheme, control: CarouselControlsTheme, }; export const ProfileReleaseRatings = (props: any) => { const [modal, setModal] = useState(false); return (

Оценки

{props.ratings.map((release) => { return (

{release.title_ru}

= 1} /> = 2} /> = 3} /> = 4} /> = 5} />

{unixToDate(release.voted_at, "full")}

); })}
); }; const ProfileReleaseRatingsModal = (props: { isOpen: boolean; setIsOpen: any; profile_id: number; token: string | null; }) => { const [currentRef, setCurrentRef] = useState(null); const modalRef = useCallback((ref) => { setCurrentRef(ref); }, []); const getKey = (pageIndex: number, previousPageData: any) => { if (previousPageData && !previousPageData.content.length) return null; let url = `${ENDPOINTS.user.profile}/vote/release/voted/${props.profile_id}/${pageIndex}?sort=1`; if (props.token) { url += `&token=${props.token}`; } return url; }; const { data, error, isLoading, size, setSize } = useSWRInfinite( getKey, useSWRfetcher, { initialSize: 2 } ); const [content, setContent] = useState([]); useEffect(() => { if (data) { let allReleases = []; for (let i = 0; i < data.length; i++) { allReleases.push(...data[i].content); } setContent(allReleases); } }, [data]); const [scrollPosition, setScrollPosition] = useState(0); function handleScroll() { const height = currentRef.scrollHeight - currentRef.clientHeight; const windowScroll = currentRef.scrollTop; const scrolled = (windowScroll / height) * 100; setScrollPosition(Math.floor(scrolled)); } useEffect(() => { if (scrollPosition >= 95 && scrollPosition <= 96) { setSize(size + 1); } // eslint-disable-next-line react-hooks/exhaustive-deps }, [scrollPosition]); return ( props.setIsOpen(false)} size={"4xl"} > Оценки
{isLoading && } {content && content.length > 0 ? ( content.map((release) => { return (

{release.title_ru}

{release.episodes_total ? release.episodes_total : "?"}{" "} эп.

{" "} {release.grade ? release.grade.toFixed(1) : "?"} из 5

= 1} /> = 2} /> = 3} /> = 4} /> = 5} />

{unixToDate(release.voted_at, "full")}

); }) ) : (

Оценок нет

)}
); };