diff --git a/app/components/Profile/Profile.ReleaseHistory.tsx b/app/components/Profile/Profile.ReleaseHistory.tsx index b579c11..2401f32 100644 --- a/app/components/Profile/Profile.ReleaseHistory.tsx +++ b/app/components/Profile/Profile.ReleaseHistory.tsx @@ -1,49 +1,79 @@ -import { Card, Carousel } from "flowbite-react"; -import type { - FlowbiteCarouselIndicatorsTheme, - FlowbiteCarouselControlTheme, - CustomFlowbiteTheme, -} from "flowbite-react"; -import { ReleaseLink } from "../ReleaseLink/ReleaseLinkUpdate"; +import { Card } from "flowbite-react"; -const CarouselIndicatorsTheme: FlowbiteCarouselIndicatorsTheme = { - active: { - off: "bg-gray-400/50 hover:bg-gray-200", - on: "bg-gray-200", - }, - base: "h-3 w-3 rounded-full max-w-[300px]", - wrapper: "absolute bottom-5 left-1/2 flex -translate-x-1/2 space-x-3", -}; +import { ReleaseChips } from "../ReleasePoster/Chips"; +import { Poster } from "../ReleasePoster/Poster"; +import Link from "next/link"; -const CarouselControlsTheme: FlowbiteCarouselControlTheme = { - base: "inline-flex h-8 w-8 items-center justify-center rounded-full group-focus:outline-none group-focus:ring-4 bg-gray-400/30 group-hover:bg-gray-400/60 group-focus:ring-gray-400/70 sm:h-10 sm:w-10", - icon: "h-5 w-5 text-gray-400 sm:h-6 sm:w-6", -}; - -const CarouselTheme: CustomFlowbiteTheme["carousel"] = { - root: { - base: "relative h-full w-full max-w-[375px]", - }, - indicators: CarouselIndicatorsTheme, - control: CarouselControlsTheme, +const profile_lists = { + // 0: "Не смотрю", + 1: { name: "Смотрю", bg_color: "bg-green-500" }, + 2: { name: "В планах", bg_color: "bg-purple-500" }, + 3: { name: "Просмотрено", bg_color: "bg-blue-500" }, + 4: { name: "Отложено", bg_color: "bg-yellow-500" }, + 5: { name: "Брошено", bg_color: "bg-red-500" }, }; export const ProfileReleaseHistory = (props: any) => { return (

Недавно просмотренные

-
- - {props.history.map((release) => { - return ( - - ); - })} - +
+ {props.history.map((release) => { + const genres = []; + const grade = release.grade ? Number(release.grade.toFixed(1)) : null; + const profile_list_status = release.profile_list_status || null; + let user_list = null; + if (profile_list_status != null || profile_list_status != 0) { + user_list = profile_lists[profile_list_status]; + } + if (release.genres) { + const genres_array = release.genres.split(","); + genres_array.forEach((genre) => { + genres.push(genre.trim()); + }); + } + return ( + +
+
+ +
+
+ +
+ {genres.length > 0 && + genres.map((genre: string, index: number) => { + return ( + + {index > 0 && ", "} + {genre} + + ); + })} +
+ {release.title_ru && ( +

+ {release.title_ru} +

+ )} + {release.title_original && ( +

+ {release.title_original} +

+ )} +
+
+ + ); + })}
); diff --git a/app/components/Profile/Profile.ReleaseRatings.tsx b/app/components/Profile/Profile.ReleaseRatings.tsx index 0808d0a..ffdeee9 100644 --- a/app/components/Profile/Profile.ReleaseRatings.tsx +++ b/app/components/Profile/Profile.ReleaseRatings.tsx @@ -1,16 +1,11 @@ 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"; @@ -19,28 +14,6 @@ import useSWRInfinite from "swr/infinite"; import { Spinner } from "../Spinner/Spinner"; import { Poster } from "../ReleasePoster/Poster"; -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 = { - root: { - base: "relative h-full w-full max-w-[700px]", - }, - indicators: CarouselIndicatorsTheme, - control: CarouselControlsTheme, -}; - export const ProfileReleaseRatings = (props: any) => { const [modal, setModal] = useState(false); return (