mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
chore: comment crud in store mutation
This commit is contained in:
parent
6fc593bcb9
commit
1873b445ed
@ -5,11 +5,19 @@ import { useIssueDetail } from "hooks/store";
|
|||||||
// components
|
// components
|
||||||
import { IssueActivityList } from "./activity/activity-list";
|
import { IssueActivityList } from "./activity/activity-list";
|
||||||
import { IssueCommentCard } from "./comments/comment-card";
|
import { IssueCommentCard } from "./comments/comment-card";
|
||||||
|
// types
|
||||||
|
import { TActivityOperations } from "./root";
|
||||||
|
|
||||||
type TIssueActivityCommentRoot = { workspaceSlug: string; projectId: string; issueId: string; disabled: boolean };
|
type TIssueActivityCommentRoot = {
|
||||||
|
workspaceSlug: string;
|
||||||
|
projectId: string;
|
||||||
|
issueId: string;
|
||||||
|
activityOperations: TActivityOperations;
|
||||||
|
disabled: boolean;
|
||||||
|
};
|
||||||
|
|
||||||
export const IssueActivityCommentRoot: FC<TIssueActivityCommentRoot> = observer((props) => {
|
export const IssueActivityCommentRoot: FC<TIssueActivityCommentRoot> = observer((props) => {
|
||||||
const { workspaceSlug, projectId, issueId, disabled } = props;
|
const { workspaceSlug, projectId, issueId, activityOperations, disabled } = props;
|
||||||
// hooks
|
// hooks
|
||||||
const {
|
const {
|
||||||
activity: { getActivityCommentByIssueId },
|
activity: { getActivityCommentByIssueId },
|
||||||
@ -28,6 +36,7 @@ export const IssueActivityCommentRoot: FC<TIssueActivityCommentRoot> = observer(
|
|||||||
projectId={projectId}
|
projectId={projectId}
|
||||||
issueId={issueId}
|
issueId={issueId}
|
||||||
commentId={activityComment.id}
|
commentId={activityComment.id}
|
||||||
|
activityOperations={activityOperations}
|
||||||
disabled={disabled}
|
disabled={disabled}
|
||||||
ends={index === 0 ? "top" : index === activityComments.length - 1 ? "bottom" : undefined}
|
ends={index === 0 ? "top" : index === activityComments.length - 1 ? "bottom" : undefined}
|
||||||
/>
|
/>
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { FC, useEffect, useRef, useState } from "react";
|
import { FC, useEffect, useRef, useState } from "react";
|
||||||
import { useForm } from "react-hook-form";
|
import { useForm } from "react-hook-form";
|
||||||
import { Check, Globe2, Lock, MessageSquare, Pencil, Trash2, X } from "lucide-react";
|
import { Check, Globe2, Lock, Pencil, Trash2, X } from "lucide-react";
|
||||||
// hooks
|
// hooks
|
||||||
import { useIssueDetail, useMention, useUser } from "hooks/store";
|
import { useIssueDetail, useMention, useUser } from "hooks/store";
|
||||||
// components
|
// components
|
||||||
@ -101,9 +101,7 @@ export const IssueCommentCard: FC<TIssueCommentCard> = (props) => {
|
|||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
<CustomMenu.MenuItem
|
<CustomMenu.MenuItem
|
||||||
onClick={() => {
|
onClick={() => activityOperations.removeComment(comment.id)}
|
||||||
activityOperations.removeComment(comment.id);
|
|
||||||
}}
|
|
||||||
className="flex items-center gap-1"
|
className="flex items-center gap-1"
|
||||||
>
|
>
|
||||||
<Trash2 className="h-3 w-3" />
|
<Trash2 className="h-3 w-3" />
|
||||||
|
@ -25,7 +25,6 @@ export const IssueCommentCreateUpdate: FC<TIssueCommentCreateUpdate> = (props) =
|
|||||||
const {
|
const {
|
||||||
handleSubmit,
|
handleSubmit,
|
||||||
control,
|
control,
|
||||||
watch,
|
|
||||||
formState: { isSubmitting },
|
formState: { isSubmitting },
|
||||||
reset,
|
reset,
|
||||||
} = useForm<Partial<TIssueComment>>({ defaultValues: { comment_html: "<p></p>" } });
|
} = useForm<Partial<TIssueComment>>({ defaultValues: { comment_html: "<p></p>" } });
|
||||||
|
@ -191,7 +191,7 @@ export const IssueActivity: FC<TIssueActivity> = observer((props) => {
|
|||||||
<div className="min-h-[200px]">
|
<div className="min-h-[200px]">
|
||||||
{activityTab === "all" ? (
|
{activityTab === "all" ? (
|
||||||
<>
|
<>
|
||||||
<IssueActivityCommentRoot {...componentCommonProps} />
|
<IssueActivityCommentRoot {...componentCommonProps} activityOperations={activityOperations} />
|
||||||
<IssueCommentCreateUpdate
|
<IssueCommentCreateUpdate
|
||||||
workspaceSlug={workspaceSlug}
|
workspaceSlug={workspaceSlug}
|
||||||
activityOperations={activityOperations}
|
activityOperations={activityOperations}
|
||||||
|
@ -3,7 +3,7 @@ import set from "lodash/set";
|
|||||||
import sortBy from "lodash/sortBy";
|
import sortBy from "lodash/sortBy";
|
||||||
import update from "lodash/update";
|
import update from "lodash/update";
|
||||||
import concat from "lodash/concat";
|
import concat from "lodash/concat";
|
||||||
import merge from "lodash/merge";
|
import uniq from "lodash/uniq";
|
||||||
// services
|
// services
|
||||||
import { IssueActivityService } from "services/issue";
|
import { IssueActivityService } from "services/issue";
|
||||||
// types
|
// types
|
||||||
@ -122,7 +122,7 @@ export class IssueActivityStore implements IIssueActivityStore {
|
|||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
update(this.activities, issueId, (_activityIds) => {
|
update(this.activities, issueId, (_activityIds) => {
|
||||||
if (!_activityIds) return activityIds;
|
if (!_activityIds) return activityIds;
|
||||||
return merge(_activityIds, activityIds);
|
return uniq(concat(_activityIds, activityIds));
|
||||||
});
|
});
|
||||||
activities.forEach((activity) => {
|
activities.forEach((activity) => {
|
||||||
set(this.activityMap, activity.id, activity);
|
set(this.activityMap, activity.id, activity);
|
||||||
|
@ -2,7 +2,8 @@ import { action, makeObservable, observable, runInAction } from "mobx";
|
|||||||
import set from "lodash/set";
|
import set from "lodash/set";
|
||||||
import update from "lodash/update";
|
import update from "lodash/update";
|
||||||
import concat from "lodash/concat";
|
import concat from "lodash/concat";
|
||||||
import merge from "lodash/merge";
|
import uniq from "lodash/uniq";
|
||||||
|
import pull from "lodash/pull";
|
||||||
// services
|
// services
|
||||||
import { IssueCommentService } from "services/issue";
|
import { IssueCommentService } from "services/issue";
|
||||||
// types
|
// types
|
||||||
@ -97,7 +98,7 @@ export class IssueCommentStore implements IIssueCommentStore {
|
|||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
update(this.comments, issueId, (_commentIds) => {
|
update(this.comments, issueId, (_commentIds) => {
|
||||||
if (!_commentIds) return commentIds;
|
if (!_commentIds) return commentIds;
|
||||||
return merge(_commentIds, commentIds);
|
return uniq(concat(_commentIds, commentIds));
|
||||||
});
|
});
|
||||||
comments.forEach((comment) => {
|
comments.forEach((comment) => {
|
||||||
set(this.commentMap, comment.id, comment);
|
set(this.commentMap, comment.id, comment);
|
||||||
@ -116,8 +117,11 @@ export class IssueCommentStore implements IIssueCommentStore {
|
|||||||
const response = await this.issueCommentService.createIssueComment(workspaceSlug, projectId, issueId, data);
|
const response = await this.issueCommentService.createIssueComment(workspaceSlug, projectId, issueId, data);
|
||||||
|
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
this.comments[issueId].push(response.id);
|
update(this.comments, issueId, (_commentIds) => {
|
||||||
set(this.rootIssueDetail.activity.activityMap, response.id, response);
|
if (!_commentIds) return [response.id];
|
||||||
|
return uniq(concat(_commentIds, [response.id]));
|
||||||
|
});
|
||||||
|
set(this.commentMap, response.id, response);
|
||||||
});
|
});
|
||||||
|
|
||||||
return response;
|
return response;
|
||||||
@ -159,10 +163,8 @@ export class IssueCommentStore implements IIssueCommentStore {
|
|||||||
try {
|
try {
|
||||||
const response = await this.issueCommentService.deleteIssueComment(workspaceSlug, projectId, issueId, commentId);
|
const response = await this.issueCommentService.deleteIssueComment(workspaceSlug, projectId, issueId, commentId);
|
||||||
|
|
||||||
const reactionIndex = this.comments[issueId].findIndex((_comment) => _comment === commentId);
|
|
||||||
if (reactionIndex >= 0)
|
|
||||||
runInAction(() => {
|
runInAction(() => {
|
||||||
this.comments[issueId].splice(reactionIndex, 1);
|
pull(this.comments[issueId], commentId);
|
||||||
delete this.commentMap[commentId];
|
delete this.commentMap[commentId];
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -95,8 +95,16 @@ export class IssueStore implements IIssueStore {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
updateIssue = async (workspaceSlug: string, projectId: string, issueId: string, data: Partial<TIssue>) =>
|
updateIssue = async (workspaceSlug: string, projectId: string, issueId: string, data: Partial<TIssue>) => {
|
||||||
this.rootIssueDetailStore.rootIssueStore.projectIssues.updateIssue(workspaceSlug, projectId, issueId, data);
|
const issue = await this.rootIssueDetailStore.rootIssueStore.projectIssues.updateIssue(
|
||||||
|
workspaceSlug,
|
||||||
|
projectId,
|
||||||
|
issueId,
|
||||||
|
data
|
||||||
|
);
|
||||||
|
await this.rootIssueDetailStore.activity.fetchActivities(workspaceSlug, projectId, issueId);
|
||||||
|
return issue;
|
||||||
|
};
|
||||||
|
|
||||||
removeIssue = async (workspaceSlug: string, projectId: string, issueId: string) =>
|
removeIssue = async (workspaceSlug: string, projectId: string, issueId: string) =>
|
||||||
this.rootIssueDetailStore.rootIssueStore.projectIssues.removeIssue(workspaceSlug, projectId, issueId);
|
this.rootIssueDetailStore.rootIssueStore.projectIssues.removeIssue(workspaceSlug, projectId, issueId);
|
||||||
|
@ -126,6 +126,8 @@ export class IssueReactionStore implements IIssueReactionStore {
|
|||||||
set(this.reactionMap, response.id, response);
|
set(this.reactionMap, response.id, response);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// fetching activity
|
||||||
|
this.rootIssueDetailStore.activity.fetchActivities(workspaceSlug, projectId, issueId);
|
||||||
return response;
|
return response;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
throw error;
|
throw error;
|
||||||
@ -152,6 +154,8 @@ export class IssueReactionStore implements IIssueReactionStore {
|
|||||||
|
|
||||||
const response = await this.issueReactionService.deleteIssueReaction(workspaceSlug, projectId, issueId, reaction);
|
const response = await this.issueReactionService.deleteIssueReaction(workspaceSlug, projectId, issueId, reaction);
|
||||||
|
|
||||||
|
// fetching activity
|
||||||
|
this.rootIssueDetailStore.activity.fetchActivities(workspaceSlug, projectId, issueId);
|
||||||
return response;
|
return response;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
throw error;
|
throw error;
|
||||||
|
@ -124,6 +124,8 @@ export class IssueRelationStore implements IIssueRelationStore {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// fetching activity
|
||||||
|
this.rootIssueDetailStore.activity.fetchActivities(workspaceSlug, projectId, issueId);
|
||||||
return response;
|
return response;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
throw error;
|
throw error;
|
||||||
@ -149,6 +151,8 @@ export class IssueRelationStore implements IIssueRelationStore {
|
|||||||
related_issue,
|
related_issue,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// fetching activity
|
||||||
|
this.rootIssueDetailStore.activity.fetchActivities(workspaceSlug, projectId, issueId);
|
||||||
return response;
|
return response;
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
this.fetchRelations(workspaceSlug, projectId, issueId);
|
this.fetchRelations(workspaceSlug, projectId, issueId);
|
||||||
|
Loading…
Reference in New Issue
Block a user