mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
47681fe9f8
* add concurrency to dev command to avaoid erroring out * add context to issue activity * minor quality of life improvement for exporter modal * show the option to save draft issue only when there is content in name and description * maintain commonality while referencing the user in activity * fix minor changes in draft save issue modal logical condition * minor change is state component for filter selection * change logic for create issue activity * change use last draft issue button to state control over previous on hover as that was inconsistent
98 lines
3.6 KiB
TypeScript
98 lines
3.6 KiB
TypeScript
import { useRouter } from "next/router";
|
||
import useSWR from "swr";
|
||
import { observer } from "mobx-react";
|
||
//hooks
|
||
import { useUser } from "hooks/store";
|
||
// services
|
||
import { UserService } from "services/user.service";
|
||
// components
|
||
import { ActivityMessage, IssueLink } from "components/core";
|
||
// ui
|
||
import { ProfileEmptyState } from "components/ui";
|
||
import { Loader } from "@plane/ui";
|
||
// image
|
||
import recentActivityEmptyState from "public/empty-state/recent_activity.svg";
|
||
// helpers
|
||
import { calculateTimeAgo } from "helpers/date-time.helper";
|
||
// fetch-keys
|
||
import { USER_PROFILE_ACTIVITY } from "constants/fetch-keys";
|
||
|
||
// services
|
||
const userService = new UserService();
|
||
|
||
export const ProfileActivity = observer(() => {
|
||
const router = useRouter();
|
||
const { workspaceSlug, userId } = router.query;
|
||
// store hooks
|
||
const { currentUser } = useUser();
|
||
|
||
const { data: userProfileActivity } = useSWR(
|
||
workspaceSlug && userId ? USER_PROFILE_ACTIVITY(workspaceSlug.toString(), userId.toString()) : null,
|
||
workspaceSlug && userId
|
||
? () => userService.getUserProfileActivity(workspaceSlug.toString(), userId.toString())
|
||
: null
|
||
);
|
||
|
||
return (
|
||
<div className="space-y-2">
|
||
<h3 className="text-lg font-medium">Recent Activity</h3>
|
||
<div className="rounded border border-custom-border-100 p-6">
|
||
{userProfileActivity ? (
|
||
userProfileActivity.results.length > 0 ? (
|
||
<div className="space-y-5">
|
||
{userProfileActivity.results.map((activity) => (
|
||
<div key={activity.id} className="flex gap-3">
|
||
<div className="flex-shrink-0">
|
||
{activity.actor_detail.avatar && activity.actor_detail.avatar !== "" ? (
|
||
<img
|
||
src={activity.actor_detail.avatar}
|
||
alt={activity.actor_detail.display_name}
|
||
height={24}
|
||
width={24}
|
||
className="rounded"
|
||
/>
|
||
) : (
|
||
<div className="grid h-6 w-6 place-items-center rounded border-2 bg-gray-700 text-xs text-white">
|
||
{activity.actor_detail.display_name?.charAt(0)}
|
||
</div>
|
||
)}
|
||
</div>
|
||
<div className="-mt-1 w-4/5 break-words">
|
||
<p className="text-sm text-custom-text-200">
|
||
<span className="font-medium text-custom-text-100">
|
||
{currentUser?.id === activity.actor_detail.id ? "You" : activity.actor_detail.display_name}{" "}
|
||
</span>
|
||
{activity.field ? (
|
||
<ActivityMessage activity={activity} showIssue />
|
||
) : (
|
||
<span>
|
||
created <IssueLink activity={activity} />
|
||
</span>
|
||
)}
|
||
</p>
|
||
<p className="text-xs text-custom-text-200">{calculateTimeAgo(activity.created_at)}</p>
|
||
</div>
|
||
</div>
|
||
))}
|
||
</div>
|
||
) : (
|
||
<ProfileEmptyState
|
||
title="No Data yet"
|
||
description="We couldn’t find data. Kindly view your inputs"
|
||
image={recentActivityEmptyState}
|
||
/>
|
||
)
|
||
) : (
|
||
<Loader className="space-y-5">
|
||
<Loader.Item height="40px" />
|
||
<Loader.Item height="40px" />
|
||
<Loader.Item height="40px" />
|
||
<Loader.Item height="40px" />
|
||
<Loader.Item height="40px" />
|
||
</Loader>
|
||
)}
|
||
</div>
|
||
</div>
|
||
);
|
||
});
|