forked from github/plane
313 lines
9.5 KiB
TypeScript
313 lines
9.5 KiB
TypeScript
|
// icons
|
||
|
import { Icon } from "components/ui";
|
||
|
import { Squares2X2Icon } from "@heroicons/react/24/outline";
|
||
|
import { BlockedIcon, BlockerIcon } from "components/icons";
|
||
|
// helpers
|
||
|
import { renderShortDateWithYearFormat } from "helpers/date-time.helper";
|
||
|
import { capitalizeFirstLetter } from "helpers/string.helper";
|
||
|
// types
|
||
|
import { IIssueActivity } from "types";
|
||
|
|
||
|
export const activityDetails: {
|
||
|
[key: string]: {
|
||
|
message: (activity: IIssueActivity) => React.ReactNode;
|
||
|
icon: React.ReactNode;
|
||
|
};
|
||
|
} = {
|
||
|
assignees: {
|
||
|
message: (activity) => {
|
||
|
if (activity.old_value === "")
|
||
|
return (
|
||
|
<>
|
||
|
added a new assignee{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
removed the assignee{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.old_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <Icon iconName="group" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
archived_at: {
|
||
|
message: (activity) => {
|
||
|
if (activity.new_value === "restore") return "restored the issue.";
|
||
|
else return "archived the issue.";
|
||
|
},
|
||
|
icon: <Icon iconName="archive" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
attachment: {
|
||
|
message: (activity) => {
|
||
|
if (activity.verb === "created")
|
||
|
return (
|
||
|
<>
|
||
|
uploaded a new{" "}
|
||
|
<a
|
||
|
href={`${activity.new_value}`}
|
||
|
target="_blank"
|
||
|
rel="noopener noreferrer"
|
||
|
className="font-medium text-custom-text-100 inline-flex items-center gap-1 hover:underline"
|
||
|
>
|
||
|
attachment
|
||
|
<Icon iconName="launch" className="!text-xs" />
|
||
|
</a>
|
||
|
</>
|
||
|
);
|
||
|
else return "removed an attachment.";
|
||
|
},
|
||
|
icon: <Icon iconName="attach_file" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
blocking: {
|
||
|
message: (activity) => {
|
||
|
if (activity.old_value === "")
|
||
|
return (
|
||
|
<>
|
||
|
marked this issue is blocking issue{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
removed the blocking issue{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.old_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <BlockerIcon height="12" width="12" color="#6b7280" />,
|
||
|
},
|
||
|
blocks: {
|
||
|
message: (activity) => {
|
||
|
if (activity.old_value === "")
|
||
|
return (
|
||
|
<>
|
||
|
marked this issue is being blocked by{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
removed this issue being blocked by issue{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.old_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <BlockedIcon height="12" width="12" color="#6b7280" />,
|
||
|
},
|
||
|
cycles: {
|
||
|
message: (activity) => {
|
||
|
if (activity.verb === "created")
|
||
|
return (
|
||
|
<>
|
||
|
added this issue to the cycle{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
else if (activity.verb === "updated")
|
||
|
return (
|
||
|
<>
|
||
|
set the cycle to{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
removed the issue from the cycle{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.old_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <Icon iconName="contrast" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
description: {
|
||
|
message: (activity) => "updated the description.",
|
||
|
icon: <Icon iconName="chat" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
estimate_point: {
|
||
|
message: (activity) => {
|
||
|
if (!activity.new_value) return "removed the estimate point.";
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
set the estimate point to{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <Icon iconName="change_history" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
issue: {
|
||
|
message: (activity) => {
|
||
|
if (activity.verb === "created") return "created the issue.";
|
||
|
else return "deleted an issue.";
|
||
|
},
|
||
|
icon: <Icon iconName="stack" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
labels: {
|
||
|
message: (activity) => {
|
||
|
if (activity.old_value === "")
|
||
|
return (
|
||
|
<>
|
||
|
added a new label{" "}
|
||
|
<span className="inline-flex items-center gap-3 rounded-full border border-custom-border-300 px-2 py-0.5 text-xs">
|
||
|
<span
|
||
|
className="h-1.5 w-1.5 rounded-full"
|
||
|
style={{
|
||
|
backgroundColor: "#000000",
|
||
|
}}
|
||
|
aria-hidden="true"
|
||
|
/>
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>
|
||
|
</span>
|
||
|
</>
|
||
|
);
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
removed the label{" "}
|
||
|
<span className="inline-flex items-center gap-3 rounded-full border border-custom-border-300 px-2 py-0.5 text-xs">
|
||
|
<span
|
||
|
className="h-1.5 w-1.5 rounded-full"
|
||
|
style={{
|
||
|
backgroundColor: "#000000",
|
||
|
}}
|
||
|
aria-hidden="true"
|
||
|
/>
|
||
|
<span className="font-medium text-custom-text-100">{activity.old_value}</span>
|
||
|
</span>
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <Icon iconName="sell" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
link: {
|
||
|
message: (activity) => {
|
||
|
if (activity.verb === "created")
|
||
|
return (
|
||
|
<>
|
||
|
added this{" "}
|
||
|
<a
|
||
|
href={`${activity.new_value}`}
|
||
|
target="_blank"
|
||
|
rel="noopener noreferrer"
|
||
|
className="font-medium text-custom-text-100 inline-flex items-center gap-1 hover:underline"
|
||
|
>
|
||
|
link
|
||
|
<Icon iconName="launch" className="!text-xs" />
|
||
|
</a>{" "}
|
||
|
to the issue.
|
||
|
</>
|
||
|
);
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
removed this{" "}
|
||
|
<a
|
||
|
href={`${activity.old_value}`}
|
||
|
target="_blank"
|
||
|
rel="noopener noreferrer"
|
||
|
className="font-medium text-custom-text-100 inline-flex items-center gap-1 hover:underline"
|
||
|
>
|
||
|
link
|
||
|
<Icon iconName="launch" className="!text-xs" />
|
||
|
</a>{" "}
|
||
|
from the issue.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <Icon iconName="link" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
modules: {
|
||
|
message: (activity) => {
|
||
|
if (activity.verb === "created")
|
||
|
return (
|
||
|
<>
|
||
|
added this issue to the module{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
else if (activity.verb === "updated")
|
||
|
return (
|
||
|
<>
|
||
|
set the module to{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
removed the issue from the module{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.old_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <Icon iconName="dataset" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
name: {
|
||
|
message: (activity) => `set the name to ${activity.new_value}.`,
|
||
|
icon: <Icon iconName="chat" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
parent: {
|
||
|
message: (activity) => {
|
||
|
if (!activity.new_value)
|
||
|
return (
|
||
|
<>
|
||
|
removed the parent{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.old_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
set the parent to{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <Icon iconName="supervised_user_circle" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
priority: {
|
||
|
message: (activity) => (
|
||
|
<>
|
||
|
set the priority to{" "}
|
||
|
<span className="font-medium text-custom-text-100">
|
||
|
{activity.new_value ? capitalizeFirstLetter(activity.new_value) : "None"}
|
||
|
</span>
|
||
|
.
|
||
|
</>
|
||
|
),
|
||
|
icon: <Icon iconName="signal_cellular_alt" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
state: {
|
||
|
message: (activity) => (
|
||
|
<>
|
||
|
set the state to{" "}
|
||
|
<span className="font-medium text-custom-text-100">{activity.new_value}</span>.
|
||
|
</>
|
||
|
),
|
||
|
icon: <Squares2X2Icon className="h-3 w-3" aria-hidden="true" />,
|
||
|
},
|
||
|
target_date: {
|
||
|
message: (activity) => {
|
||
|
if (!activity.new_value) return "removed the due date.";
|
||
|
else
|
||
|
return (
|
||
|
<>
|
||
|
set the due date to{" "}
|
||
|
<span className="font-medium text-custom-text-100">
|
||
|
{renderShortDateWithYearFormat(activity.new_value)}
|
||
|
</span>
|
||
|
.
|
||
|
</>
|
||
|
);
|
||
|
},
|
||
|
icon: <Icon iconName="calendar_today" className="!text-sm" aria-hidden="true" />,
|
||
|
},
|
||
|
};
|