2023-10-20 12:25:20 +00:00
|
|
|
import { FC } from "react";
|
|
|
|
import useSWR from "swr";
|
|
|
|
import { observer } from "mobx-react-lite";
|
|
|
|
// components
|
2023-12-07 12:43:27 +00:00
|
|
|
import { IssuePeekOverviewReactions } from "components/issues";
|
2023-10-20 12:25:20 +00:00
|
|
|
// hooks
|
|
|
|
import { useMobxStore } from "lib/mobx/store-provider";
|
|
|
|
// types
|
2023-12-11 09:06:34 +00:00
|
|
|
import { RootStore } from "store_legacy/root";
|
2023-10-20 12:25:20 +00:00
|
|
|
|
|
|
|
interface IIssueCommentReaction {
|
2023-10-25 13:54:14 +00:00
|
|
|
workspaceSlug: string;
|
|
|
|
projectId: string;
|
|
|
|
issueId: string;
|
2023-10-20 12:25:20 +00:00
|
|
|
user: any;
|
|
|
|
|
|
|
|
comment: any;
|
|
|
|
issueCommentReactionCreate: (commentId: string, reaction: string) => void;
|
|
|
|
issueCommentReactionRemove: (commentId: string, reaction: string) => void;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const IssueCommentReaction: FC<IIssueCommentReaction> = observer((props) => {
|
2023-10-25 13:54:14 +00:00
|
|
|
const { workspaceSlug, projectId, issueId, user, comment, issueCommentReactionCreate, issueCommentReactionRemove } =
|
|
|
|
props;
|
2023-10-20 12:25:20 +00:00
|
|
|
|
|
|
|
const { issueDetail: issueDetailStore }: RootStore = useMobxStore();
|
|
|
|
|
|
|
|
const handleCommentReactionCreate = (reaction: string) => {
|
|
|
|
if (issueCommentReactionCreate && comment?.id) issueCommentReactionCreate(comment?.id, reaction);
|
|
|
|
};
|
|
|
|
|
|
|
|
const handleCommentReactionRemove = (reaction: string) => {
|
|
|
|
if (issueCommentReactionRemove && comment?.id) issueCommentReactionRemove(comment?.id, reaction);
|
|
|
|
};
|
|
|
|
|
|
|
|
useSWR(
|
2023-10-25 13:54:14 +00:00
|
|
|
workspaceSlug && projectId && issueId && comment && comment?.id
|
|
|
|
? `ISSUE+PEEK_OVERVIEW_COMMENT_${comment?.id}`
|
|
|
|
: null,
|
2023-10-20 12:25:20 +00:00
|
|
|
() => {
|
2023-10-25 13:54:14 +00:00
|
|
|
if (workspaceSlug && projectId && issueId && comment && comment.id) {
|
|
|
|
issueDetailStore.fetchIssueCommentReactions(workspaceSlug, projectId, issueId, comment?.id);
|
2023-10-20 12:25:20 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2023-10-25 13:54:14 +00:00
|
|
|
let issueReactions = issueDetailStore?.getIssueCommentReactions || null;
|
|
|
|
issueReactions = issueReactions && comment.id ? issueReactions?.[comment.id] : [];
|
2023-10-20 12:25:20 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
2023-12-07 12:43:27 +00:00
|
|
|
<IssuePeekOverviewReactions
|
2023-10-20 12:25:20 +00:00
|
|
|
issueReactions={issueReactions}
|
|
|
|
user={user}
|
|
|
|
issueReactionCreate={handleCommentReactionCreate}
|
|
|
|
issueReactionRemove={handleCommentReactionRemove}
|
|
|
|
position="top"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
});
|