2024-02-05 13:42:33 +00:00
|
|
|
import { observer } from "mobx-react";
|
2024-01-18 10:19:54 +00:00
|
|
|
import { Tab } from "@headlessui/react";
|
|
|
|
// helpers
|
|
|
|
import { cn } from "helpers/common.helper";
|
2024-02-05 13:42:33 +00:00
|
|
|
// types
|
|
|
|
import { TDurationFilterOptions, TIssuesListTypes } from "@plane/types";
|
2024-01-18 10:19:54 +00:00
|
|
|
// constants
|
2024-02-05 13:42:33 +00:00
|
|
|
import { FILTERED_ISSUES_TABS_LIST, UNFILTERED_ISSUES_TABS_LIST } from "constants/dashboard";
|
2024-01-18 10:19:54 +00:00
|
|
|
|
2024-02-05 13:42:33 +00:00
|
|
|
type Props = {
|
|
|
|
durationFilter: TDurationFilterOptions;
|
|
|
|
selectedTab: TIssuesListTypes;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const TabsList: React.FC<Props> = observer((props) => {
|
|
|
|
const { durationFilter, selectedTab } = props;
|
|
|
|
|
|
|
|
const tabsList = durationFilter === "none" ? UNFILTERED_ISSUES_TABS_LIST : FILTERED_ISSUES_TABS_LIST;
|
|
|
|
const selectedTabIndex = tabsList.findIndex((tab) => tab.key === (selectedTab ?? "pending"));
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Tab.List
|
|
|
|
as="div"
|
2024-02-08 13:51:08 +00:00
|
|
|
className="relative border-[0.5px] border-neutral-border-medium rounded bg-neutral-component-surface-dark grid"
|
2024-02-05 13:42:33 +00:00
|
|
|
style={{
|
|
|
|
gridTemplateColumns: `repeat(${tabsList.length}, 1fr)`,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<div
|
|
|
|
className={cn("absolute bg-custom-background-100 rounded transition-all duration-500 ease-in-out", {
|
|
|
|
// right shadow
|
|
|
|
"shadow-[2px_0_8px_rgba(167,169,174,0.15)]": selectedTabIndex !== tabsList.length - 1,
|
|
|
|
// left shadow
|
|
|
|
"shadow-[-2px_0_8px_rgba(167,169,174,0.15)]": selectedTabIndex !== 0,
|
|
|
|
})}
|
|
|
|
style={{
|
|
|
|
height: "calc(100% - 1px)",
|
|
|
|
width: `${100 / tabsList.length}%`,
|
|
|
|
transform: `translateX(${selectedTabIndex * 100}%)`,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
{tabsList.map((tab) => (
|
|
|
|
<Tab
|
|
|
|
key={tab.key}
|
|
|
|
className={cn(
|
2024-02-08 12:53:13 +00:00
|
|
|
"relative z-[1] font-semibold text-xs rounded py-1.5 text-neutral-text-subtle focus:outline-none",
|
2024-02-05 13:42:33 +00:00
|
|
|
"transition duration-500",
|
|
|
|
{
|
2024-02-08 12:53:13 +00:00
|
|
|
"text-neutral-text-strong bg-custom-background-100": selectedTab === tab.key,
|
|
|
|
"hover:text-neutral-text-medium": selectedTab !== tab.key,
|
2024-02-05 13:42:33 +00:00
|
|
|
// // right shadow
|
|
|
|
// "shadow-[2px_0_8px_rgba(167,169,174,0.15)]": selectedTabIndex !== tabsList.length - 1,
|
|
|
|
// // left shadow
|
|
|
|
// "shadow-[-2px_0_8px_rgba(167,169,174,0.15)]": selectedTabIndex !== 0,
|
|
|
|
}
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
<span className="scale-110">{tab.label}</span>
|
|
|
|
</Tab>
|
|
|
|
))}
|
|
|
|
</Tab.List>
|
|
|
|
);
|
|
|
|
});
|