mirror of
https://github.com/Radiquum/AniX.git
synced 2025-04-05 15:54:39 +00:00
107 lines
3 KiB
TypeScript
107 lines
3 KiB
TypeScript
"use client";
|
||
import { Button, ButtonGroup, Card } from "flowbite-react";
|
||
// import Link from "next/link";
|
||
// import { numberDeclension } from "#/api/utils";
|
||
import { ProfileActivityCollections } from "./Profile.ActivityCollections";
|
||
import { useEffect, useState } from "react";
|
||
import { CollectionCourusel } from "../CollectionCourusel/CollectionCourusel";
|
||
import { ProfileActivityFriends } from "./Profile.ActivityFriends";
|
||
|
||
export function ProfileActivity(props: {
|
||
profile_id: number;
|
||
commentCount: number;
|
||
videoCount: number;
|
||
collectionCount: number;
|
||
collectionPreview: any;
|
||
friendsCount: number;
|
||
friendsPreview: any;
|
||
token: string;
|
||
isMyProfile: boolean;
|
||
}) {
|
||
const [tab, setTab] = useState<
|
||
"collections" | "comments" | "friends" | "videos"
|
||
>("collections");
|
||
|
||
const [collections, setCollections] = useState<Record<number, any>>({});
|
||
|
||
function _setCollection(array: any[]) {
|
||
if (array && array.length == 0) {
|
||
return;
|
||
}
|
||
let _coll = array.filter((col) => {
|
||
if (typeof col == "number") {
|
||
return false;
|
||
}
|
||
return true;
|
||
});
|
||
_coll.map((col) => {
|
||
setCollections((prev) => {
|
||
return {
|
||
...prev,
|
||
[col.id]: col,
|
||
};
|
||
});
|
||
|
||
if (
|
||
col.creator.collections_preview &&
|
||
col.creator.collections_preview.length > 0
|
||
) {
|
||
_setCollection(col.creator.collections_preview || []);
|
||
}
|
||
});
|
||
}
|
||
|
||
useEffect(() => {
|
||
_setCollection(props.collectionPreview || []);
|
||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||
}, [props.collectionPreview]);
|
||
|
||
return (
|
||
<Card className="overflow-hidden h-fit">
|
||
<h1 className="text-2xl font-bold">Активность</h1>
|
||
<ButtonGroup>
|
||
<Button
|
||
color={tab == "collections" ? "blue" : "light"}
|
||
onClick={() => setTab("collections")}
|
||
>
|
||
Коллекции | {props.collectionCount}
|
||
</Button>
|
||
<Button
|
||
color={tab == "comments" ? "blue" : "light"}
|
||
onClick={() => setTab("comments")}
|
||
>
|
||
Комментарии | {props.commentCount}
|
||
</Button>
|
||
<Button
|
||
color={tab == "friends" ? "blue" : "light"}
|
||
onClick={() => setTab("friends")}
|
||
>
|
||
Друзья | {props.friendsCount}
|
||
</Button>
|
||
<Button
|
||
color={tab == "videos" ? "blue" : "light"}
|
||
onClick={() => setTab("videos")}
|
||
>
|
||
Видео | {props.videoCount}
|
||
</Button>
|
||
</ButtonGroup>
|
||
|
||
{tab == "collections" && (
|
||
<ProfileActivityCollections
|
||
content={Object.values(collections) || []}
|
||
profile_id={props.profile_id}
|
||
/>
|
||
)}
|
||
{tab == "comments" && <>comments</>}
|
||
{tab == "friends" && (
|
||
<ProfileActivityFriends
|
||
token={props.token}
|
||
content={props.friendsPreview || []}
|
||
isMyProfile={props.isMyProfile}
|
||
profile_id={props.profile_id}
|
||
/>
|
||
)}
|
||
{tab == "videos" && <>videos</>}
|
||
</Card>
|
||
);
|
||
}
|