plane/apps/space/components/issues/peek-overview/issue-activity.tsx

42 lines
1.2 KiB
TypeScript
Raw Normal View History

import React, { useEffect } from "react";
2023-08-30 18:42:45 +00:00
import { useRouter } from "next/router";
import { observer } from "mobx-react-lite";
2023-08-30 18:42:45 +00:00
// lib
import { useMobxStore } from "lib/mobx/store-provider";
2023-08-30 18:42:45 +00:00
// components
import { CommentCard, AddComment } from "components/issues/peek-overview";
2023-08-30 18:42:45 +00:00
// types
import { IIssue } from "types";
type Props = {
2023-08-30 18:42:45 +00:00
issueDetails: IIssue;
};
export const PeekOverviewIssueActivity: React.FC<Props> = observer((props) => {
2023-08-30 18:42:45 +00:00
const router = useRouter();
const { workspaceSlug } = router.query;
2023-08-30 18:42:45 +00:00
const { issueDetails: issueDetailStore, user: userStore } = useMobxStore();
2023-08-30 18:42:45 +00:00
const issueId = issueDetailStore?.peekId;
const comments = issueDetailStore?.details[issueId ?? ""]?.comments ?? [];
return (
<div>
<h4 className="font-medium">Activity</h4>
2023-08-30 18:42:45 +00:00
{workspaceSlug && (
<div className="mt-4">
2023-08-30 18:42:45 +00:00
<div className="space-y-4">
{comments.map((comment: any) => (
<CommentCard comment={comment} workspaceSlug={workspaceSlug?.toString()} />
))}
</div>
<div className="mt-4">
<AddComment disabled={!userStore.currentUser} issueId={issueId} />
</div>
</div>
2023-08-30 18:42:45 +00:00
)}
</div>
);
});