Skip to content

Commit 869c755

Browse files
[WEB-3698] fix: comments refactor (#6759)
* fix: comments refactor * fix: add edited at * chore: add edited_at validation at issue comment update * fix: comment mentions * fix: edited at * fix: css * fix: added bulk asset upload api * fix: projectId prop fixed * fix: css * fix: refactor * fix: translation --------- Co-authored-by: pablohashescobar <[email protected]>
1 parent a5ffbff commit 869c755

36 files changed

+577
-360
lines changed

apiserver/plane/app/views/issue/comment.py

+7-1
Original file line numberDiff line numberDiff line change
@@ -105,7 +105,13 @@ def partial_update(self, request, slug, project_id, issue_id, pk):
105105
issue_comment, data=request.data, partial=True
106106
)
107107
if serializer.is_valid():
108-
serializer.save()
108+
if (
109+
"comment_html" in request.data
110+
and request.data["comment_html"] != issue_comment.comment_html
111+
):
112+
serializer.save(edited_at=timezone.now())
113+
else:
114+
serializer.save()
109115
issue_activity.delay(
110116
type="comment.activity.updated",
111117
requested_data=requested_data,

packages/i18n/src/locales/en/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -331,6 +331,8 @@
331331
"re_generate_key": "Re-generate key",
332332
"export": "Export",
333333
"member": "{count, plural, one{# member} other{# members}}",
334+
"edited": "edited",
335+
"bot": "Bot",
334336

335337
"project_view": {
336338
"sort_by": {

packages/i18n/src/locales/es/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -503,6 +503,8 @@
503503
"re_generate_key": "Regenerar clave",
504504
"export": "Exportar",
505505
"member": "{count, plural, one{# miembro} other{# miembros}}",
506+
"edited": "Modificado",
507+
"bot": "Bot",
506508

507509
"project_view": {
508510
"sort_by": {

packages/i18n/src/locales/fr/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -501,6 +501,8 @@
501501
"re_generate_key": "Régénérer la clé",
502502
"export": "Exporter",
503503
"member": "{count, plural, one{# membre} other{# membres}}",
504+
"edited": "Modifié",
505+
"bot": "Bot",
504506

505507
"project_view": {
506508
"sort_by": {

packages/i18n/src/locales/it/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -500,6 +500,8 @@
500500
"re_generate_key": "Rigenera chiave",
501501
"export": "Esporta",
502502
"member": "{count, plural, one {# membro} other {# membri}}",
503+
"edited": "Modificato",
504+
"bot": "Bot",
503505

504506
"project_view": {
505507
"sort_by": {

packages/i18n/src/locales/ja/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -501,6 +501,8 @@
501501
"re_generate_key": "キーを再生成",
502502
"export": "エクスポート",
503503
"member": "{count, plural, other{# メンバー}}",
504+
"edited": "編集済み",
505+
"bot": "ボット",
504506

505507
"project_view": {
506508
"sort_by": {

packages/i18n/src/locales/ko/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -501,6 +501,8 @@
501501
"re_generate_key": "키 다시 생성",
502502
"export": "내보내기",
503503
"member": "{count, plural, one{# 멤버} other{# 멤버}}",
504+
"edited": "수정됨",
505+
"bot": "",
504506

505507
"project_view": {
506508
"sort_by": {

packages/i18n/src/locales/pl/translations.json

+3
Original file line numberDiff line numberDiff line change
@@ -499,6 +499,9 @@
499499
"re_generate_key": "Wygeneruj klucz ponownie",
500500
"export": "Eksportuj",
501501
"member": "{count, plural, one{# członek} few{# członkowie} other{# członków}}",
502+
"edited": "Edytowano",
503+
"bot": "Bot",
504+
502505
"project_view": {
503506
"sort_by": {
504507
"created_at": "Utworzono dnia",

packages/i18n/src/locales/ru/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -499,6 +499,8 @@
499499
"re_generate_key": "Перегенерировать ключ",
500500
"export": "Экспорт",
501501
"member": "{count, plural, one{# участник} few{# участника} other{# участников}}",
502+
"edited": "Редактировано",
503+
"bot": "Бот",
502504

503505
"project_view": {
504506
"sort_by": {

packages/i18n/src/locales/sk/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -499,6 +499,8 @@
499499
"re_generate_key": "Znova generovať kľúč",
500500
"export": "Exportovať",
501501
"member": "{count, plural, one{# člen} few{# členovia} other{# členov}}",
502+
"edited": "Upravené",
503+
"bot": "Bot",
502504

503505
"project_view": {
504506
"sort_by": {

packages/i18n/src/locales/ua/translations.json

+3
Original file line numberDiff line numberDiff line change
@@ -499,6 +499,9 @@
499499
"re_generate_key": "Повторно згенерувати ключ",
500500
"export": "Експортувати",
501501
"member": "{count, plural, one{# учасник} few{# учасники} other{# учасників}}",
502+
"edited": "Редагувано",
503+
"bot": "Бот",
504+
502505
"project_view": {
503506
"sort_by": {
504507
"created_at": "Створено",

packages/i18n/src/locales/zh-CN/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -501,6 +501,8 @@
501501
"re_generate_key": "重新生成密钥",
502502
"export": "导出",
503503
"member": "{count, plural, other{# 成员}}",
504+
"edited": "已编辑",
505+
"bot": "机器人",
504506

505507
"project_view": {
506508
"sort_by": {

packages/i18n/src/locales/zh-TW/translations.json

+2
Original file line numberDiff line numberDiff line change
@@ -501,6 +501,8 @@
501501
"re_generate_key": "重新產生金鑰",
502502
"export": "匯出",
503503
"member": "{count, plural, one{# 位成員} other{# 位成員}}",
504+
"edited": "已編輯",
505+
"bot": "機器人",
504506

505507
"project_view": {
506508
"sort_by": {

packages/types/src/issues/activity/issue_comment.d.ts

+26
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,15 @@ import {
55
TIssueActivityUserDetail,
66
} from "./base";
77
import { EIssueCommentAccessSpecifier } from "../../enums";
8+
import { TFileSignedURLResponse } from "../../file";
9+
import { IUserLite } from "../../users";
810

11+
export type TCommentReaction = {
12+
id: string;
13+
reaction: string;
14+
actor: string;
15+
actor_detail: IUserLite;
16+
};
917
export type TIssueComment = {
1018
id: string;
1119
workspace: string;
@@ -17,6 +25,7 @@ export type TIssueComment = {
1725
actor: string;
1826
actor_detail: TIssueActivityUserDetail;
1927
created_at: string;
28+
edited_at?: string | undefined;
2029
updated_at: string;
2130
created_by: string | undefined;
2231
updated_by: string | undefined;
@@ -30,6 +39,23 @@ export type TIssueComment = {
3039
access: EIssueCommentAccessSpecifier;
3140
};
3241

42+
export type TCommentsOperations = {
43+
createComment: (data: Partial<TIssueComment>) => Promise<void>;
44+
updateComment: (commentId: string, data: Partial<TIssueComment>) => Promise<void>;
45+
removeComment: (commentId: string) => Promise<void>;
46+
uploadCommentAsset: (blockId: string, file: File, commentId?: string) => Promise<TFileSignedURLResponse>;
47+
addCommentReaction: (commentId: string, reactionEmoji: string) => Promise<void>;
48+
deleteCommentReaction: (commentId: string, reactionEmoji: string, userReactions: TCommentReaction[]) => Promise<void>;
49+
react: (commentId: string, reactionEmoji: string, userReactions: string[]) => Promise<void>;
50+
reactionIds: (commentId: string) =>
51+
| {
52+
[reaction: string]: string[];
53+
}
54+
| undefined;
55+
userReactions: (commentId: string) => string[] | undefined;
56+
getReactionUsers: (reaction: string, reactionIds: Record<string, string[]>) => string;
57+
};
58+
3359
export type TIssueCommentMap = {
3460
[issue_id: string]: TIssueComment;
3561
};
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
import { FC, ReactNode, useRef } from "react";
2+
import { observer } from "mobx-react";
3+
// plane imports
4+
import { useTranslation } from "@plane/i18n";
5+
import { TIssueComment } from "@plane/types";
6+
import { Avatar, Tooltip } from "@plane/ui";
7+
import { calculateTimeAgo, cn, getFileURL, renderFormattedDate } from "@plane/utils";
8+
// hooks
9+
import { renderFormattedTime } from "@/helpers/date-time.helper";
10+
import { useMember } from "@/hooks/store";
11+
12+
type TCommentBlock = {
13+
comment: TIssueComment;
14+
ends: "top" | "bottom" | undefined;
15+
quickActions: ReactNode;
16+
children: ReactNode;
17+
};
18+
19+
export const CommentBlock: FC<TCommentBlock> = observer((props) => {
20+
const { comment, ends, quickActions, children } = props;
21+
const commentBlockRef = useRef<HTMLDivElement>(null);
22+
// store hooks
23+
const { getUserDetails } = useMember();
24+
const { t } = useTranslation();
25+
const userDetails = getUserDetails(comment?.actor);
26+
27+
if (!comment || !userDetails) return <></>;
28+
return (
29+
<div
30+
className={`relative flex gap-3 ${ends === "top" ? `pb-2` : ends === "bottom" ? `pt-2` : `py-2`}`}
31+
ref={commentBlockRef}
32+
>
33+
<div
34+
className="absolute left-[13px] top-0 bottom-0 w-0.5 transition-border duration-1000 bg-custom-background-80"
35+
aria-hidden
36+
/>
37+
<div
38+
className={cn(
39+
"flex-shrink-0 relative w-7 h-6 rounded-full transition-border duration-1000 flex justify-center items-center z-[3] uppercase font-medium"
40+
)}
41+
>
42+
<Avatar
43+
size="base"
44+
name={userDetails?.display_name}
45+
src={getFileURL(userDetails?.avatar_url)}
46+
className="flex-shrink-0"
47+
/>
48+
</div>
49+
<div className="flex flex-col gap-3 truncate flex-grow">
50+
<div className="flex w-full gap-2">
51+
<div className="flex-1 flex flex-wrap items-center gap-1">
52+
<div className="text-xs font-medium">
53+
{comment?.actor_detail?.is_bot
54+
? comment?.actor_detail?.first_name + ` ${t("bot")}`
55+
: comment?.actor_detail?.display_name || userDetails.display_name}
56+
</div>
57+
<div className="text-xs text-custom-text-300">
58+
commented{" "}
59+
<Tooltip
60+
tooltipContent={`${renderFormattedDate(comment.created_at)} at ${renderFormattedTime(comment.created_at)}`}
61+
position="bottom"
62+
>
63+
<span className="text-custom-text-350">
64+
{calculateTimeAgo(comment.updated_at)}
65+
{comment.edited_at && ` (${t("edited")})`}
66+
</span>
67+
</Tooltip>
68+
</div>
69+
</div>
70+
<div className="flex-shrink-0 ">{quickActions}</div>
71+
</div>
72+
<div className="text-base mb-2">{children}</div>
73+
</div>
74+
</div>
75+
);
76+
});

web/ce/components/comments/index.ts

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
export * from "./comment-block";

0 commit comments

Comments
 (0)