mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
72 lines
1.8 KiB
TypeScript
72 lines
1.8 KiB
TypeScript
import { FC } from "react";
|
|
import Link from "next/link";
|
|
// types
|
|
import { TPageNavigationTabs } from "@plane/types";
|
|
// constants
|
|
import { PAGES_TAB_CHANGED, E_PAGES } from "@/constants/event-tracker";
|
|
// helpers
|
|
import { cn } from "@/helpers/common.helper";
|
|
// hooks
|
|
import { useEventTracker } from "@/hooks/store";
|
|
|
|
type TPageTabNavigation = {
|
|
workspaceSlug: string;
|
|
projectId: string;
|
|
pageType: TPageNavigationTabs;
|
|
};
|
|
|
|
// pages tab options
|
|
const pageTabs: { key: TPageNavigationTabs; label: string }[] = [
|
|
{
|
|
key: "public",
|
|
label: "Public",
|
|
},
|
|
{
|
|
key: "private",
|
|
label: "Private",
|
|
},
|
|
{
|
|
key: "archived",
|
|
label: "Archived",
|
|
},
|
|
];
|
|
|
|
export const PageTabNavigation: FC<TPageTabNavigation> = (props) => {
|
|
const { workspaceSlug, projectId, pageType } = props;
|
|
// store hooks
|
|
const { captureEvent } = useEventTracker();
|
|
|
|
const handleTabClick = (e: React.MouseEvent<HTMLAnchorElement>, tabKey: TPageNavigationTabs) => {
|
|
if (tabKey === pageType) e.preventDefault();
|
|
captureEvent(PAGES_TAB_CHANGED, {
|
|
tab: tabKey,
|
|
element: E_PAGES,
|
|
});
|
|
};
|
|
|
|
return (
|
|
<div className="relative flex items-center">
|
|
{pageTabs.map((tab) => (
|
|
<Link
|
|
key={tab.key}
|
|
href={`/${workspaceSlug}/projects/${projectId}/pages?type=${tab.key}`}
|
|
onClick={(e) => handleTabClick(e, tab.key)}
|
|
>
|
|
<span
|
|
className={cn(`block p-3 py-4 text-sm font-medium transition-all`, {
|
|
"text-custom-primary-100": tab.key === pageType,
|
|
})}
|
|
>
|
|
{tab.label}
|
|
</span>
|
|
<div
|
|
className={cn(`rounded-t border-t-2 transition-all border-transparent`, {
|
|
"border-custom-primary-100": tab.key === pageType,
|
|
})}
|
|
/>
|
|
</Link>
|
|
))}
|
|
</div>
|
|
);
|
|
};
|