style: finished module card design (#593)

* style: finished modulecard design

* fix: use assignee list component
This commit is contained in:
kunalv17 2023-03-30 01:17:51 +05:30 committed by GitHub
parent c75ca8203f
commit 5c1607f39b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 43 additions and 56 deletions

View File

@ -43,6 +43,7 @@ export * from "./user-icon";
export * from "./grid-view-icons"; export * from "./grid-view-icons";
export * from "./assignment-clipboard-icon"; export * from "./assignment-clipboard-icon";
export * from "./tick-mark-icon"; export * from "./tick-mark-icon";
export * from "./target-icon"
export * from "./contrast-icon"; export * from "./contrast-icon";
export * from "./people-group-icon"; export * from "./people-group-icon";
export * from "./cmd-icon"; export * from "./cmd-icon";

View File

@ -0,0 +1,20 @@
import React from "react";
import type { Props } from "./types";
export const TargetIcon: React.FC<Props> = ({
width = "24",
height = "24",
className,
color = "black",
}) => (
<svg width={width} height={height} className={className} color={color} viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg" xlinkHref="http://www.w3.org/1999/xlink">
<rect width="16" height="16" fill="url(#pattern0)"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlinkHref="#image0_2094_50417" transform="scale(0.01)"/>
</pattern>
<image id="image0_2094_50417" width="100" height="100" xlinkHref=""/>
</defs>
</svg>
);

View File

@ -26,7 +26,7 @@ export const ModuleStatusSelect: React.FC<Props> = ({ control, error }) => (
value={value} value={value}
label={ label={
<div <div
className={`flex items-center justify-center gap-2 text-xs ${ className={`flex items-center justify-center h-6 gap-2 text-xs ${
error ? "text-red-500" : "" error ? "text-red-500" : ""
}`} }`}
> >

View File

@ -2,7 +2,6 @@ import React, { useState } from "react";
import Link from "next/link"; import Link from "next/link";
import { useRouter } from "next/router"; import { useRouter } from "next/router";
import Image from "next/image";
import { mutate } from "swr"; import { mutate } from "swr";
@ -15,16 +14,14 @@ import { DeleteModuleModal } from "components/modules";
// ui // ui
import { AssigneesList, Avatar, CustomMenu, Tooltip } from "components/ui"; import { AssigneesList, Avatar, CustomMenu, Tooltip } from "components/ui";
// icons // icons
import User from "public/user.png";
import { import {
CalendarDaysIcon,
DocumentDuplicateIcon, DocumentDuplicateIcon,
PencilIcon, PencilIcon,
StarIcon, StarIcon,
TrashIcon, TrashIcon,
UserCircleIcon,
UserGroupIcon,
} from "@heroicons/react/24/outline"; } from "@heroicons/react/24/outline";
import { CalendarMonthIcon, TargetIcon } from "components/icons";
// helpers // helpers
import { copyTextToClipboard, truncateText } from "helpers/string.helper"; import { copyTextToClipboard, truncateText } from "helpers/string.helper";
import { renderShortDateWithYearFormat } from "helpers/date-time.helper"; import { renderShortDateWithYearFormat } from "helpers/date-time.helper";
@ -121,6 +118,7 @@ export const SingleModuleCard: React.FC<Props> = ({ module, handleEditModule })
const endDate = new Date(module.target_date ?? ""); const endDate = new Date(module.target_date ?? "");
const startDate = new Date(module.start_date ?? ""); const startDate = new Date(module.start_date ?? "");
const lastUpdated = new Date(module.updated_at ?? "");
return ( return (
<> <>
@ -129,14 +127,14 @@ export const SingleModuleCard: React.FC<Props> = ({ module, handleEditModule })
setIsOpen={setModuleDeleteModal} setIsOpen={setModuleDeleteModal}
data={module} data={module}
/> />
<div className="flex flex-col rounded-[10px] border bg-white text-xs"> <div className="flex flex-col overflow-hidden rounded-[10px] divide-y border bg-white text-xs">
<div className="p-4"> <div className="p-4">
<div className="flex w-full flex-col gap-5"> <div className="flex w-full flex-col gap-5">
<div className="flex items-start justify-between gap-2"> <div className="flex items-start justify-between gap-2">
<Tooltip tooltipContent={module.name} position="top-left"> <Tooltip tooltipContent={module.name} position="top-left">
<Link href={`/${workspaceSlug}/projects/${module.project}/modules/${module.id}`}> <Link href={`/${workspaceSlug}/projects/${module.project}/modules/${module.id}`}>
<a className="w-full"> <a className="w-auto max-w-[calc(100%-9rem)]">
<h3 className="break-all text-lg font-semibold text-black"> <h3 className="break-all text-lg truncate font-semibold text-black">
{truncateText(module.name, 75)} {truncateText(module.name, 75)}
</h3> </h3>
</a> </a>
@ -144,7 +142,7 @@ export const SingleModuleCard: React.FC<Props> = ({ module, handleEditModule })
</Tooltip> </Tooltip>
<div className="flex items-center gap-1"> <div className="flex items-center gap-1">
<div className="mr-2 rounded bg-gray-100 px-2.5 py-2"> <div className="mr-2 rounded flex bg-gray-100 px-2.5 py-2">
<span className="capitalize">{module?.status?.replace("-", " ")}</span> <span className="capitalize">{module?.status?.replace("-", " ")}</span>
</div> </div>
{module.is_favorite ? ( {module.is_favorite ? (
@ -181,62 +179,19 @@ export const SingleModuleCard: React.FC<Props> = ({ module, handleEditModule })
</div> </div>
<div className="grid grid-cols-2 gap-4"> <div className="grid grid-cols-2 gap-4">
<div className="flex items-start gap-1"> <div className="flex items-start gap-1">
<CalendarDaysIcon className="h-4 w-4 text-gray-900" /> <CalendarMonthIcon className="h-4 w-4 text-gray-900" />
<span className="text-gray-400">Start:</span> <span className="text-gray-400">Start:</span>
<span>{renderShortDateWithYearFormat(startDate)}</span> <span>{renderShortDateWithYearFormat(startDate)}</span>
</div> </div>
<div className="flex items-start gap-1"> <div className="flex items-start gap-1">
<CalendarDaysIcon className="h-4 w-4 text-gray-900" /> <TargetIcon className="h-4 w-4 text-gray-900" />
<span className="text-gray-400">End:</span> <span className="text-gray-400">End:</span>
<span>{renderShortDateWithYearFormat(endDate)}</span> <span>{renderShortDateWithYearFormat(endDate)}</span>
</div> </div>
<div className="flex items-center gap-1.5">
<UserCircleIcon className="h-4 w-4 text-gray-900" />
<span className="text-gray-400">Lead:</span>
<div>
{module.lead_detail ? (
<div className="flex items-center gap-1">
<Avatar user={module.lead_detail} />
<span>{module.lead_detail.first_name}</span>
</div>
) : (
<div className="flex items-center gap-1">
<Image
src={User}
height="12px"
width="12px"
className="rounded-full"
alt="N/A"
/>
<span>N/A</span>
</div>
)}
</div>
</div>
<div className="flex items-center gap-1.5">
<UserGroupIcon className="h-4 w-4 text-gray-900" />
<span className="text-gray-400">Members:</span>
<div className="flex items-center gap-1 text-xs">
{module.members && module.members.length > 0 ? (
<AssigneesList userIds={module.members} length={3} />
) : (
<div className="flex items-center gap-1">
<Image
src={User}
height="16px"
width="16px"
className="rounded-full"
alt="N/A"
/>
<span>N/A</span>
</div>
)}
</div> </div>
</div> </div>
</div> </div>
</div> <div className="flex flex-col h-full items-end">
</div>
<div className="flex h-full items-end">
<div className="flex w-full items-center justify-between gap-2 justify-self-end bg-gray-100 p-4"> <div className="flex w-full items-center justify-between gap-2 justify-self-end bg-gray-100 p-4">
<span>Progress</span> <span>Progress</span>
<div className="bar relative h-1 w-full rounded bg-gray-300"> <div className="bar relative h-1 w-full rounded bg-gray-300">
@ -249,6 +204,17 @@ export const SingleModuleCard: React.FC<Props> = ({ module, handleEditModule })
</div> </div>
<span>{isNaN(completionPercentage) ? 0 : completionPercentage.toFixed(0)}%</span> <span>{isNaN(completionPercentage) ? 0 : completionPercentage.toFixed(0)}%</span>
</div> </div>
<div className="flex justify-between w-full px-4 pb-4 bg-gray-100 item-center">
<p className="text-[#858E96]">
Last updated:
<span className="text-black font-medium">
{renderShortDateWithYearFormat(lastUpdated)}
</span>
</p>
<div className="flex items-center gap-1">
<AssigneesList users={module.members_detail} length={4} />
</div>
</div>
</div> </div>
</div> </div>
</> </>