forked from github/plane
87 lines
3.3 KiB
TypeScript
87 lines
3.3 KiB
TypeScript
// ui
|
|
import { IUserProfileData, IUserStateDistribution } from "@plane/types";
|
|
import { ProfileEmptyState, PieGraph } from "@/components/ui";
|
|
// image
|
|
import { STATE_GROUPS } from "@/constants/state";
|
|
import stateGraph from "public/empty-state/state_graph.svg";
|
|
// types
|
|
// constants
|
|
|
|
type Props = {
|
|
stateDistribution: IUserStateDistribution[];
|
|
userProfile: IUserProfileData | undefined;
|
|
};
|
|
|
|
export const ProfileStateDistribution: React.FC<Props> = ({ stateDistribution, userProfile }) => {
|
|
if (!userProfile) return null;
|
|
|
|
return (
|
|
<div className="flex flex-col space-y-2">
|
|
<h3 className="text-lg font-medium">Issues by state</h3>
|
|
<div className="flex-grow rounded border border-custom-border-100 p-7">
|
|
{userProfile.state_distribution.length > 0 ? (
|
|
<div className="grid grid-cols-1 gap-x-6 md:grid-cols-2">
|
|
<div>
|
|
<PieGraph
|
|
data={
|
|
userProfile.state_distribution.map((group) => ({
|
|
id: group.state_group,
|
|
label: group.state_group,
|
|
value: group.state_count,
|
|
color: STATE_GROUPS[group.state_group]?.color ?? "rgb(var(--color-primary-100))",
|
|
})) ?? []
|
|
}
|
|
height="250px"
|
|
innerRadius={0.6}
|
|
cornerRadius={5}
|
|
padAngle={2}
|
|
enableArcLabels
|
|
arcLabelsTextColor="#000000"
|
|
enableArcLinkLabels={false}
|
|
activeInnerRadiusOffset={5}
|
|
colors={(datum) => datum?.data?.color}
|
|
tooltip={(datum) => (
|
|
<div className="flex items-center gap-2 rounded-md border border-custom-border-200 bg-custom-background-90 p-2 text-xs">
|
|
<span className="capitalize text-custom-text-200">{datum.datum.label} issues:</span>{" "}
|
|
{datum.datum.value}
|
|
</div>
|
|
)}
|
|
margin={{
|
|
top: 32,
|
|
right: 0,
|
|
bottom: 32,
|
|
left: 0,
|
|
}}
|
|
/>
|
|
</div>
|
|
<div className="flex items-center">
|
|
<div className="w-full space-y-4">
|
|
{stateDistribution.map((group) => (
|
|
<div key={group.state_group} className="flex items-center justify-between gap-2 text-xs">
|
|
<div className="flex items-center gap-1.5">
|
|
<div
|
|
className="h-2.5 w-2.5 rounded-sm"
|
|
style={{
|
|
backgroundColor: STATE_GROUPS[group.state_group]?.color ?? "rgb(var(--color-primary-100))",
|
|
}}
|
|
/>
|
|
<div className="whitespace-nowrap">{STATE_GROUPS[group.state_group].label}</div>
|
|
</div>
|
|
<div>{group.state_count}</div>
|
|
</div>
|
|
))}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
) : (
|
|
<ProfileEmptyState
|
|
title="No Data yet"
|
|
description="Create issues to view the them by states in the graph for better analysis."
|
|
image={stateGraph}
|
|
/>
|
|
)}
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|