2024-05-23 10:07:25 +00:00
|
|
|
import { FC } from "react";
|
|
|
|
import Image from "next/image";
|
|
|
|
import { useTheme } from "next-themes";
|
|
|
|
import { Button } from "@plane/ui";
|
2024-05-24 11:54:50 +00:00
|
|
|
// public images
|
|
|
|
import EstimateEmptyDarkImage from "@/public/empty-state/estimates/dark.svg";
|
|
|
|
import EstimateEmptyLightImage from "@/public/empty-state/estimates/light.svg";
|
2024-05-23 10:07:25 +00:00
|
|
|
|
|
|
|
type TEstimateEmptyScreen = {
|
|
|
|
onButtonClick: () => void;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const EstimateEmptyScreen: FC<TEstimateEmptyScreen> = (props) => {
|
|
|
|
// props
|
|
|
|
const { onButtonClick } = props;
|
|
|
|
const { resolvedTheme } = useTheme();
|
|
|
|
|
2024-05-24 11:54:50 +00:00
|
|
|
const emptyScreenImage = resolvedTheme === "light" ? EstimateEmptyLightImage : EstimateEmptyDarkImage;
|
2024-05-23 10:07:25 +00:00
|
|
|
|
|
|
|
return (
|
2024-05-23 11:23:48 +00:00
|
|
|
<div className="relative flex flex-col justify-center items-center text-center gap-8 border border-custom-border-300 rounded bg-custom-background-90 py-10">
|
2024-05-23 10:07:25 +00:00
|
|
|
<div className="flex-shrink-0 w-[120px] h-[120px] overflow-hidden relative flex justify-center items-center">
|
|
|
|
<Image
|
|
|
|
src={emptyScreenImage}
|
|
|
|
alt="Empty estimate image"
|
|
|
|
width={100}
|
|
|
|
height={100}
|
|
|
|
className="object-contain w-full h-full"
|
|
|
|
/>
|
|
|
|
</div>
|
2024-05-23 11:23:48 +00:00
|
|
|
<div className="space-y-1.5">
|
|
|
|
<h3 className="text-xl font-semibold text-custom-text-100">No estimate systems yet</h3>
|
|
|
|
<p className="text-sm text-custom-text-300">
|
|
|
|
Create a set of estimates to communicate the amount of work per issue.
|
|
|
|
</p>
|
2024-05-23 10:07:25 +00:00
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<Button onClick={onButtonClick}>Add Estimate System</Button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|