mirror of
https://github.com/Radiquum/AniX.git
synced 2025-04-04 23:34:38 +00:00
Some checks are pending
V3 Preview Deployment / Deploy-Preview (push) Waiting to run
112 lines
3.2 KiB
TypeScript
112 lines
3.2 KiB
TypeScript
"use client";
|
||
import { Button, ButtonGroup, Card } from "flowbite-react";
|
||
import { ProfileActivityCollections } from "./Profile.ActivityCollections";
|
||
import { useEffect, useState } from "react";
|
||
import { ProfileActivityFriends } from "./Profile.ActivityFriends";
|
||
import { ProfileActivityComment } from "./Profile.ActivityComment";
|
||
|
||
export function ProfileActivity(props: {
|
||
profile_id: number;
|
||
commentCount: number;
|
||
commentPreview: any;
|
||
collectionCount: number;
|
||
collectionPreview: any;
|
||
friendsCount: number;
|
||
friendsPreview: any;
|
||
token: string;
|
||
isMyProfile: boolean;
|
||
}) {
|
||
const [tab, setTab] = useState<"collections" | "comments" | "friends">(
|
||
"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")}
|
||
>
|
||
<div className="flex flex-col gap-1 sm:flex-row sm:items-center">
|
||
<p>Коллекции</p>
|
||
<p>( {props.collectionCount} )</p>
|
||
</div>
|
||
</Button>
|
||
<Button
|
||
color={tab == "comments" ? "blue" : "light"}
|
||
onClick={() => setTab("comments")}
|
||
>
|
||
<div className="flex flex-col gap-1 sm:flex-row sm:items-center">
|
||
<p>Комментарии</p>
|
||
<p>( {props.commentCount} )</p>
|
||
</div>
|
||
</Button>
|
||
<Button
|
||
color={tab == "friends" ? "blue" : "light"}
|
||
onClick={() => setTab("friends")}
|
||
>
|
||
<div className="flex flex-col gap-1 sm:flex-row sm:items-center">
|
||
<p>Друзья</p>
|
||
<p>( {props.friendsCount} )</p>
|
||
</div>
|
||
</Button>
|
||
</ButtonGroup>
|
||
|
||
{tab == "collections" && (
|
||
<ProfileActivityCollections
|
||
content={Object.values(collections) || []}
|
||
profile_id={props.profile_id}
|
||
/>
|
||
)}
|
||
{tab == "comments" && (
|
||
<ProfileActivityComment
|
||
content={props.commentPreview || []}
|
||
profile_id={props.profile_id}
|
||
/>
|
||
)}
|
||
{tab == "friends" && (
|
||
<ProfileActivityFriends
|
||
token={props.token}
|
||
content={props.friendsPreview || []}
|
||
isMyProfile={props.isMyProfile}
|
||
profile_id={props.profile_id}
|
||
/>
|
||
)}
|
||
</Card>
|
||
);
|
||
}
|