forked from github/plane
5a32d10f96
* chore: replaced marimekko graph with a bar graph * chore: add bar onClick handler * chore: custom date filter for widgets * style: priority graph * chore: workspace profile activity pagination * chore: profile activity pagination * chore: user profile activity pagination * chore: workspace user activity csv download * chore: download activity button added * chore: workspace user pagination * chore: collabrator pagination * chore: field change * chore: recent collaborators pagination * chore: changed the collabrators * chore: collabrators list changed * fix: distinct users * chore: search filter in collaborators * fix: import error * chore: update priority graph x-axis values * chore: admin and member request validation * chore: update csv download request method * chore: search implementation for the collaborators widget * refactor: priority distribution card * chore: add enum for duration filters * chore: update inbox types * chore: add todos for refactoring --------- Co-authored-by: NarayanBavisetti <narayan3119@gmail.com>
87 lines
3.2 KiB
TypeScript
87 lines
3.2 KiB
TypeScript
// ui
|
|
import { ProfileEmptyState, PieGraph } from "components/ui";
|
|
// image
|
|
import stateGraph from "public/empty-state/state_graph.svg";
|
|
// types
|
|
import { IUserProfileData, IUserStateDistribution } from "@plane/types";
|
|
// constants
|
|
import { STATE_GROUPS } from "constants/state";
|
|
|
|
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,
|
|
})) ?? []
|
|
}
|
|
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,
|
|
}}
|
|
/>
|
|
<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>
|
|
);
|
|
};
|