2024-02-08 18:11:30 +00:00
|
|
|
import { FC, Fragment } from "react";
|
2024-02-05 14:39:17 +00:00
|
|
|
import { observer } from "mobx-react-lite";
|
|
|
|
import { LucideIcon, List, Kanban, Calendar, Sheet, GanttChartSquare } from "lucide-react";
|
|
|
|
// hooks
|
|
|
|
import { useViewDetail } from "hooks/store";
|
|
|
|
// ui
|
|
|
|
import { Tooltip } from "@plane/ui";
|
|
|
|
// types
|
2024-02-13 13:11:34 +00:00
|
|
|
import { TViewTypes } from "@plane/types";
|
|
|
|
// constants
|
|
|
|
import { EViewLayouts, EViewPageType, viewPageDefaultLayoutsByPageType } from "constants/view";
|
2024-02-05 14:39:17 +00:00
|
|
|
|
|
|
|
type TViewLayoutRoot = {
|
|
|
|
workspaceSlug: string;
|
|
|
|
projectId: string | undefined;
|
|
|
|
viewId: string;
|
|
|
|
viewType: TViewTypes;
|
2024-02-13 13:11:34 +00:00
|
|
|
viewPageType: EViewPageType;
|
2024-02-05 14:39:17 +00:00
|
|
|
};
|
|
|
|
|
2024-02-13 13:11:34 +00:00
|
|
|
const LAYOUTS_DATA: { key: EViewLayouts; title: string; icon: LucideIcon }[] = [
|
|
|
|
{ key: EViewLayouts.LIST, title: "List Layout", icon: List },
|
|
|
|
{ key: EViewLayouts.KANBAN, title: "Kanban Layout", icon: Kanban },
|
|
|
|
{ key: EViewLayouts.CALENDAR, title: "Calendar Layout", icon: Calendar },
|
|
|
|
{ key: EViewLayouts.SPREADSHEET, title: "Spreadsheet Layout", icon: Sheet },
|
|
|
|
{ key: EViewLayouts.GANTT, title: "Gantt Chart layout", icon: GanttChartSquare },
|
2024-02-05 14:39:17 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
export const ViewLayoutRoot: FC<TViewLayoutRoot> = observer((props) => {
|
2024-02-13 13:11:34 +00:00
|
|
|
const { workspaceSlug, projectId, viewId, viewType, viewPageType } = props;
|
2024-02-05 14:39:17 +00:00
|
|
|
// hooks
|
|
|
|
const viewDetailStore = useViewDetail(workspaceSlug, projectId, viewId, viewType);
|
|
|
|
|
2024-02-13 13:11:34 +00:00
|
|
|
const validLayouts = viewPageDefaultLayoutsByPageType(viewPageType);
|
|
|
|
|
|
|
|
if (!viewDetailStore || validLayouts.length <= 1) return <></>;
|
2024-02-05 14:39:17 +00:00
|
|
|
return (
|
2024-02-12 07:00:59 +00:00
|
|
|
<div className="relative flex gap-0.5 items-center bg-custom-background-80 rounded p-1 shadow-custom-shadow-2xs">
|
2024-02-13 13:11:34 +00:00
|
|
|
{LAYOUTS_DATA.map((layout) => {
|
|
|
|
if (!validLayouts.includes(layout.key)) return <Fragment key={layout.key} />;
|
|
|
|
return (
|
|
|
|
<Fragment key={layout.key}>
|
|
|
|
<Tooltip tooltipContent={layout.title} position="bottom">
|
|
|
|
<div
|
|
|
|
className={`relative h-6 w-7 flex justify-center items-center overflow-hidden rounded transition-all cursor-pointer
|
2024-02-05 14:39:17 +00:00
|
|
|
${
|
|
|
|
viewDetailStore?.filtersToUpdate?.display_filters?.layout === layout.key
|
|
|
|
? `bg-custom-background-100 shadow-custom-shadow-2xs`
|
|
|
|
: `hover:bg-custom-background-100`
|
|
|
|
}
|
|
|
|
`}
|
2024-02-13 13:11:34 +00:00
|
|
|
onClick={() => viewDetailStore.setDisplayFilters({ layout: layout.key })}
|
|
|
|
>
|
|
|
|
<layout.icon size={12} />
|
|
|
|
</div>
|
|
|
|
</Tooltip>
|
|
|
|
</Fragment>
|
|
|
|
);
|
|
|
|
})}
|
2024-02-05 14:39:17 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
});
|