plane/web/components/issues/issue-layouts/kanban/headers/group-by-root.tsx
guru_sainath 43404bfcdf
Implemented swimlanes and kanban view (#2262)
* chore: issue store for kanban and calendar

* chore: updated ui for kanba and swimlanes

* chore: yarn.lock updated
2023-09-26 13:18:42 +05:30

33 lines
1.3 KiB
TypeScript

// components
import { StateHeader } from "./state";
import { StateGroupHeader } from "./state-group";
import { AssigneesHeader } from "./assignee";
import { PriorityHeader } from "./priority";
import { LabelHeader } from "./label";
import { CreatedByHeader } from "./created_by";
// mobx
import { observer } from "mobx-react-lite";
// mobx
import { useMobxStore } from "lib/mobx/store-provider";
import { RootStore } from "store/root";
export interface IKanBanGroupByHeaderRoot {
column_id: string;
}
export const KanBanGroupByHeaderRoot: React.FC<IKanBanGroupByHeaderRoot> = observer(({ column_id }) => {
const { issueFilter: issueFilterStore }: RootStore = useMobxStore();
const group_by: string | null = issueFilterStore?.userDisplayFilters?.group_by || null;
return (
<>
{group_by && group_by === "state" && <StateHeader column_id={column_id} />}
{group_by && group_by === "state_detail.group" && <StateGroupHeader column_id={column_id} />}
{group_by && group_by === "priority" && <PriorityHeader column_id={column_id} />}
{group_by && group_by === "labels" && <LabelHeader column_id={column_id} />}
{group_by && group_by === "assignees" && <AssigneesHeader column_id={column_id} />}
{group_by && group_by === "created_by" && <CreatedByHeader column_id={column_id} />}
</>
);
});