Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: cycles revamp using MobX #2443

Merged
merged 130 commits into from
Oct 16, 2023
Merged
Changes from 1 commit
Commits
Show all changes
130 commits
Select commit Hold shift + click to select a range
8d86087
chore: kanban refactoring
gurusainath Sep 4, 2023
e9b6f86
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanaba…
gurusainath Sep 4, 2023
9d334cf
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanaba…
gurusainath Sep 4, 2023
731309a
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanaba…
gurusainath Sep 5, 2023
ef630ef
chore: Implemented new kanaban board UX and implemented draggable usi…
gurusainath Sep 5, 2023
15ef2bc
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanaba…
gurusainath Sep 6, 2023
b86c30b
chore: updated yarn lock
gurusainath Sep 6, 2023
7c5936e
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 7, 2023
b9a6a00
chore: updated the store for issues and issue filters
gurusainath Sep 8, 2023
aef71fb
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 8, 2023
8c04e77
chore: resolved build error
gurusainath Sep 8, 2023
c0e3c81
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 11, 2023
0445c61
chore: created filters and updated the issue filters, display_filter …
gurusainath Sep 12, 2023
a8c5a41
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 12, 2023
0424280
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 12, 2023
3b85444
chore: implemented filters for issues
gurusainath Sep 12, 2023
834e672
chore: UI theming updates
gurusainath Sep 12, 2023
ada1bc0
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 12, 2023
698021a
chore: handled single and multi select in filter cards
gurusainath Sep 12, 2023
0ec0ad6
chore: implemented filters and views in kanaban
gurusainath Sep 13, 2023
3ffbb6a
chore: updating filters, display_filter and display properties
gurusainath Sep 14, 2023
f579712
chore: merge conflict for lucide icons resolved
gurusainath Sep 14, 2023
c67f08f
chore: filter, layout, display filters, extra filters and display pro…
gurusainath Sep 14, 2023
60883ba
chore: clean up and resolved import warnings
gurusainath Sep 14, 2023
66022ea
chore: type check
gurusainath Sep 14, 2023
28ce96a
chore: renamed gantt key to gantt_chart
gurusainath Sep 14, 2023
3c9e62d
chore: filter render UI and Functionality implementation
gurusainath Sep 14, 2023
fce6907
chore: filter empty state handling in issue filter selection
gurusainath Sep 14, 2023
d88a088
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 15, 2023
9136258
Implementing list view
sriramveeraghanta Sep 15, 2023
7b04adf
chore: kanban drag drop logic
gurusainath Sep 15, 2023
cf34d4a
merge conflicts resolved
sriramveeraghanta Sep 15, 2023
cc9ebc5
Merge pull request #2195 from makeplane/fix/list-sorting
sriramveeraghanta Sep 15, 2023
f6d4ac9
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 15, 2023
e949031
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 15, 2023
70fe830
filtering
sriramveeraghanta Sep 15, 2023
12b6ec4
Merge pull request #2197 from makeplane/fix/list-sorting
sriramveeraghanta Sep 15, 2023
a25e5ac
chore: store setup
gurusainath Sep 15, 2023
12ce6e7
Merge branch 'develop' of gurusainath:makeplane/plane into fix/kanban…
gurusainath Sep 19, 2023
906caa6
chore: handled build issues
gurusainath Sep 19, 2023
4915926
chore: store setup
gurusainath Sep 20, 2023
50c330d
conflicts
gurusainath Sep 20, 2023
908f671
user filter
gurusainath Sep 20, 2023
a328c53
chore: store setup
sriramveeraghanta Sep 20, 2023
e96bc77
chore: fixing up store
sriramveeraghanta Sep 20, 2023
6d52801
chore: store fixes and static data setup
sriramveeraghanta Sep 20, 2023
f69d346
chore: store setup for build fixes
sriramveeraghanta Sep 21, 2023
2dcaccd
fix: merge conflicts (#2231)
aaryan610 Sep 21, 2023
9b41b5b
chore: store fixes
sriramveeraghanta Sep 21, 2023
daa3094
chore: update issue detail store to handle peek overview (#2237)
aaryan610 Sep 21, 2023
6a430ed
chore: minor fixes
sriramveeraghanta Sep 22, 2023
0ebe36b
workspace project fixes
sriramveeraghanta Sep 25, 2023
27f78dd
feat: project issues topbar (#2256)
aaryan610 Sep 25, 2023
9a8dcc3
chore: minor fixes
sriramveeraghanta Sep 25, 2023
9831418
chore: filters dropdown (#2260)
aaryan610 Sep 25, 2023
2b419c0
fix: leave project fixes
sriramveeraghanta Sep 25, 2023
310a2ca
refactor: project card component refactor
sriramveeraghanta Sep 25, 2023
43404bf
Implemented swimlanes and kanban view (#2262)
gurusainath Sep 26, 2023
1b8d58a
fix: computed filters logic
aaryan610 Sep 26, 2023
7c0c0da
Merge branch 'fix/issues-layout-mobx' of https://github.com/makeplane…
aaryan610 Sep 26, 2023
c48cd3e
chore: added sub_group_by in params and handled sub-group-by render e…
gurusainath Sep 26, 2023
c342ab3
fix: ui package setup and project update form refactor
sriramveeraghanta Sep 27, 2023
151662a
fix: ui package setup
sriramveeraghanta Sep 27, 2023
ccf6bd4
Merge branch 'fix/issues-layout-mobx' of github.com:makeplane/plane i…
sriramveeraghanta Sep 27, 2023
b2d17e6
fix: minor ui fixes
sriramveeraghanta Sep 28, 2023
3bf590b
dev: calendar view layout revamp (#2293)
aaryan610 Sep 28, 2023
5af753f
chore: removed demo m-store routes
gurusainath Sep 28, 2023
2643de8
cycles changes
sriramveeraghanta Sep 28, 2023
f60dcdc
Merge branch 'fix/issues-layout-mobx' of github.com:makeplane/plane i…
sriramveeraghanta Sep 28, 2023
b70047b
chore: issues grouped kanban and swimlanes UI and functionality (#2294)
gurusainath Sep 29, 2023
479c145
refactor: filter components, constants and helper functions (#2297)
aaryan610 Sep 29, 2023
9ad1e73
dev: gantt chart implementation using MobX (#2302)
aaryan610 Sep 29, 2023
7270424
dev: spreadsheet layout implementation using MobX (#2306)
aaryan610 Sep 29, 2023
f227058
chore: refactoring cycles list
sriramveeraghanta Sep 29, 2023
405a398
feat: adding additional ui components
sriramveeraghanta Sep 29, 2023
569a6c3
dev: applied filters list implementation using MobX (#2325)
aaryan610 Oct 2, 2023
a39aa80
Merge branch 'fix/issues-layout-mobx' of github.com:makeplane/plane i…
sriramveeraghanta Oct 2, 2023
9c2ea8a
fix: cycles views list and board
sriramveeraghanta Oct 2, 2023
b1448c9
fix: cycles list rendering fixes
sriramveeraghanta Oct 2, 2023
41fd9ce
fix: layout fixes
sriramveeraghanta Oct 2, 2023
7be038a
refactor: filter components (#2359)
aaryan610 Oct 4, 2023
b5b8095
chore: issue properties for list and kanban layouts and implemented e…
gurusainath Oct 4, 2023
844a3e4
chore: filters import conflict
gurusainath Oct 4, 2023
0f47762
dev: setup module and module filter store (#2364)
aaryan610 Oct 4, 2023
547a265
chore: issue list layout (#2367)
gurusainath Oct 4, 2023
71604bb
chore: merge develop (#2388)
aaryan610 Oct 5, 2023
13874f2
fix: build erros
aaryan610 Oct 5, 2023
e28919a
chore: cycles, modules store integration, list and kanban layouts and…
gurusainath Oct 9, 2023
0ef2200
refactor: change naming convention (#2383)
aaryan610 Oct 9, 2023
f444309
fix:auth layer revamp
sriramveeraghanta Oct 10, 2023
57e2ed2
chore: Implemented list and kanban views in project modules (#2402)
gurusainath Oct 10, 2023
4dec676
dev: implement global views using MobX (#2404)
aaryan610 Oct 11, 2023
991a685
fix: Auth fixes and Layout fixes (#2408)
sriramveeraghanta Oct 11, 2023
9f61d8b
fix: analytics page fixes
sriramveeraghanta Oct 11, 2023
00b40fb
dev: implemented project views using MobX (#2410)
aaryan610 Oct 11, 2023
35a7d10
chore: plane ui library component and code refactor (#2406)
anmolsinghbhatia Oct 11, 2023
45aaf5c
chore: cycles revamp
gurusainath Oct 11, 2023
9f25f5a
chore: conflicts resolved
gurusainath Oct 11, 2023
faf0a64
fix: gitignore fixes
sriramveeraghanta Oct 11, 2023
0fcfa7e
chore: updated cycles view adn layout mutation
gurusainath Oct 11, 2023
d58d639
fix: project card fixes
sriramveeraghanta Oct 11, 2023
67b2821
chore: ui component revamp (#2415)
anmolsinghbhatia Oct 11, 2023
265e60a
chore: implement new worksapace wrapper for global views (#2412)
aaryan610 Oct 11, 2023
fcfdd74
dev: add remaining layouts to cycle (#2413)
aaryan610 Oct 11, 2023
08d9f15
fix: workspace auth wrapper changes
sriramveeraghanta Oct 11, 2023
2a4e61f
chore: project card revamp and refactor (#2416)
anmolsinghbhatia Oct 12, 2023
f2c3ad4
removing dist from ui
sriramveeraghanta Oct 12, 2023
e42dded
chore: handled edit and delete operation in cycle board view, and gan…
gurusainath Oct 12, 2023
404e6a0
refactor: analytics (#2419)
aaryan610 Oct 12, 2023
8aebf0b
refactor: folder structure, remove junk code (#2423)
aaryan610 Oct 13, 2023
9b0b5fc
fix: services fixes
sriramveeraghanta Oct 13, 2023
7b5779c
fix: store imports changes
sriramveeraghanta Oct 13, 2023
06bbc4c
fix: merge conflicts resolved from develop
sriramveeraghanta Oct 13, 2023
863d5ab
fix: services export fixes
sriramveeraghanta Oct 13, 2023
c7341ef
fix: services implementation fixes
sriramveeraghanta Oct 13, 2023
ea85f5d
fix: build issue fixes
sriramveeraghanta Oct 13, 2023
9d50d28
fix: react library fixes
sriramveeraghanta Oct 13, 2023
44df9e5
refactor: MobX store folder structure (#2435)
aaryan610 Oct 13, 2023
f7f9881
fix: service import errors (#2436)
aaryan610 Oct 14, 2023
93cd04f
build fixes
sriramveeraghanta Oct 14, 2023
bc37c02
editor ts config fixes
sriramveeraghanta Oct 14, 2023
2ce2bc8
fix: turbo and build fixes
sriramveeraghanta Oct 14, 2023
e3828db
fix: Auth screen loading implementation
sriramveeraghanta Oct 15, 2023
414908d
fix: build issues
sriramveeraghanta Oct 15, 2023
f450cf8
fix: turbo settings for ui package
sriramveeraghanta Oct 15, 2023
ad26dc8
conflict: merge conflict resolved
gurusainath Oct 16, 2023
b5e977d
chore: project active cycles requestes changed from swr to mobx
gurusainath Oct 16, 2023
7ff0976
conflict: merge conflicts resolved
gurusainath Oct 16, 2023
a7232c6
chore: imports and structuring codebase in cycles
gurusainath Oct 16, 2023
6562260
chore: removed legacy code from cycles
gurusainath Oct 16, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
chore: issues grouped kanban and swimlanes UI and functionality (#2294)
* chore: updated the all the group_by and sub_group_by UI and functionality render in kanban

* chore: kanban sorting in mobx and ui updates

* chore: ui changes and drag and drop functionality changes in kanban

* chore: issues count render in kanban default and swimlanes

* chore: Added icons to the group_by and sub_group_by in kanban and swimlanes
gurusainath authored Sep 29, 2023

Unverified

This commit is not signed, but one or more authors requires that any commit attributed to them is signed.
commit b70047b1d5e76d2e53d3fd886068f164ffa59bee
9 changes: 2 additions & 7 deletions web/components/gantt-chart/contexts/index.tsx
Original file line number Diff line number Diff line change
@@ -6,10 +6,7 @@ import { allViewsWithData, currentViewDataWithView } from "../data";

export const ChartContext = createContext<ChartContextReducer | undefined>(undefined);

const chartReducer = (
state: ChartContextData,
action: ChartContextActionPayload
): ChartContextData => {
const chartReducer = (state: ChartContextData, action: ChartContextActionPayload): ChartContextData => {
switch (action.type) {
case "CURRENT_VIEW":
return { ...state, currentView: action.payload };
@@ -50,9 +47,7 @@ export const ChartContextProvider: React.FC<{ children: React.ReactNode }> = ({
};

return (
<ChartContext.Provider
value={{ ...state, scrollLeft, updateScrollLeft, dispatch: handleDispatch }}
>
<ChartContext.Provider value={{ ...state, scrollLeft, updateScrollLeft, dispatch: handleDispatch }}>
{children}
</ChartContext.Provider>
);
80 changes: 43 additions & 37 deletions web/components/issues/issue-layouts/kanban/block.tsx
Original file line number Diff line number Diff line change
@@ -1,50 +1,56 @@
// react beautiful dnd
import { Draggable } from "@hello-pangea/dnd";
// components
import { KanBanProperties } from "./properties";

interface IssueBlockProps {
sub_group_id: string;
columnId: string;
issues: any;
isDragDisabled: boolean;
}

export const IssueBlock = ({ sub_group_id, columnId, issues }: IssueBlockProps) => {
console.log();

return (
<>
{issues && issues.length > 0 ? (
<>
{issues.map((issue: any, index: any) => (
<Draggable
draggableId={`${sub_group_id}-${columnId}-${issue.id}`}
index={index}
key={`issue-blocks-${sub_group_id}-${columnId}-${issue.id}`}
>
{(provided: any, snapshot: any) => (
export const IssueBlock = ({ sub_group_id, columnId, issues, isDragDisabled }: IssueBlockProps) => (
<>
{issues && issues.length > 0 ? (
<>
{issues.map((issue: any, index: any) => (
<Draggable
key={`issue-blocks-${sub_group_id}-${columnId}-${issue.id}`}
draggableId={`${issue.id}`}
index={index}
isDragDisabled={isDragDisabled}
>
{(provided: any, snapshot: any) => (
<div
key={issue.id}
className="p-1.5 hover:cursor-default"
{...provided.draggableProps}
{...provided.dragHandleProps}
ref={provided.innerRef}
>
<div
key={issue.id}
className="p-1.5 hover:cursor-default"
{...provided.draggableProps}
{...provided.dragHandleProps}
ref={provided.innerRef}
className={`min-h-[106px] text-sm rounded p-2 px-3 shadow-custom-shadow-2xs space-y-[8px] border transition-all bg-custom-background-100 hover:cursor-grab ${
snapshot.isDragging ? `border-custom-primary-100` : `border-transparent`
}`}
>
<div
className={`min-h-[106px] text-sm rounded p-2 px-3 shadow-custom-shadow-2xs space-y-[4px] border transition-all bg-custom-background-100 hover:cursor-grab ${
snapshot.isDragging ? `border-custom-primary-100` : `border-transparent`
}`}
>
<div className="text-xs line-clamp-1 text-custom-text-300">ONE-{issue.sequence_id}</div>
<div className="line-clamp-2 h-[40px] text-sm font-medium text-custom-text-100">{issue.name}</div>
<div className="h-[22px]">Footer</div>
<div className="text-xs line-clamp-1 text-custom-text-300">ONE-{issue.sequence_id}</div>
<div className="line-clamp-2 h-[40px] text-sm font-medium text-custom-text-100">{issue.name}</div>
<div className="min-h-[22px]">
<KanBanProperties />
</div>
</div>
)}
</Draggable>
))}
</>
) : (
<div>No issues are available.</div>
)}
</>
);
};
</div>
)}
</Draggable>
))}
</>
) : (
!isDragDisabled && (
<div className="absolute top-0 left-0 w-full h-full flex items-center justify-center">
{/* <div className="text-custom-text-300 text-sm">Drop here</div> */}
</div>
)
)}
</>
);
222 changes: 123 additions & 99 deletions web/components/issues/issue-layouts/kanban/default.tsx
Original file line number Diff line number Diff line change
@@ -5,42 +5,51 @@ import { Droppable } from "@hello-pangea/dnd";
import { KanBanGroupByHeaderRoot } from "./headers/group-by-root";
import { IssueBlock } from "./block";
// constants
import { ISSUE_STATE_GROUPS, ISSUE_PRIORITIES } from "constants/issue";
import { ISSUE_STATE_GROUPS, ISSUE_PRIORITIES, getValueFromObject } from "constants/issue";
// mobx
import { observer } from "mobx-react-lite";
// mobx
import { useMobxStore } from "lib/mobx/store-provider";
import { RootStore } from "store/root";

export interface IKanBan {
issues?: any;
export interface IGroupByKanBan {
issues: any;
sub_group_by: string | null;
group_by: string | null;
sub_group_id: string;
list: any;
listKey: string;
handleIssues?: () => void;
handleDragDrop?: (result: any) => void | undefined;
sub_group_id?: string;
isDragDisabled: boolean;
}

export const KanBan: React.FC<IKanBan> = observer(({ issues, sub_group_id = "null" }) => {
const { project: projectStore, issueFilter: issueFilterStore }: RootStore = useMobxStore();
const GroupByKanBan: React.FC<IGroupByKanBan> = observer(
({ issues, sub_group_by, group_by, sub_group_id = "null", list, listKey, isDragDisabled }) => {
const { issueKanBanView: issueKanBanViewStore }: RootStore = useMobxStore();

const group_by: string | null = issueFilterStore?.userDisplayFilters?.group_by || null;
const sub_group_by: string | null = issueFilterStore?.userDisplayFilters?.sub_group_by || null;
const verticalAlignPosition = (_list: any) =>
issueKanBanViewStore.kanBanToggle?.groupByHeaderMinMax.includes(getValueFromObject(_list, listKey) as string);

return (
<div className="relative w-full h-full">
{group_by && group_by === "state" && (
<div className="relative w-full h-full flex">
{projectStore?.projectStates &&
projectStore?.projectStates.length > 0 &&
projectStore?.projectStates.map((state) => (
<div className="flex-shrink-0 flex flex-col w-[340px]">
{sub_group_by === null && (
<div className="flex-shrink-0 w-full bg-custom-background-90 py-1 sticky top-0 z-[2]">
<KanBanGroupByHeaderRoot column_id={state?.id} />
</div>
)}
return (
<div className="relative w-full h-full flex">
{list &&
list.length > 0 &&
list.map((_list: any) => (
<div className={`flex-shrink-0 flex flex-col ${!verticalAlignPosition(_list) ? `w-[340px]` : ``}`}>
{sub_group_by === null && (
<div className="flex-shrink-0 w-full bg-custom-background-90 py-1 sticky top-0 z-[2]">
<KanBanGroupByHeaderRoot
column_id={getValueFromObject(_list, listKey) as string}
sub_group_by={sub_group_by}
group_by={group_by}
issues_count={issues?.[getValueFromObject(_list, listKey) as string].length || 0}
/>
</div>
)}

<div className="w-full h-full">
<Droppable droppableId={`${sub_group_id}-${state?.id}`}>
{!verticalAlignPosition(_list) && (
<div className="w-full min-h-[150px] h-full">
<Droppable droppableId={`${getValueFromObject(_list, listKey) as string}__${sub_group_id}`}>
{(provided: any, snapshot: any) => (
<div
className={`w-full h-full relative transition-all ${
@@ -49,102 +58,117 @@ export const KanBan: React.FC<IKanBan> = observer(({ issues, sub_group_id = "nul
{...provided.droppableProps}
ref={provided.innerRef}
>
{issues && (
<IssueBlock sub_group_id={sub_group_id} columnId={state?.id} issues={issues[state?.id]} />
{issues ? (
<IssueBlock
sub_group_id={sub_group_id}
columnId={getValueFromObject(_list, listKey) as string}
issues={issues[getValueFromObject(_list, listKey) as string]}
isDragDisabled={isDragDisabled}
/>
) : (
isDragDisabled && (
<div className="absolute top-0 left-0 w-full h-full flex items-center justify-center">
{/* <div className="text-custom-text-300 text-sm">Drop here</div> */}
</div>
)
)}
{provided.placeholder}
</div>
)}
</Droppable>
</div>
</div>
))}
</div>
)}
</div>
))}
</div>
);
}
);

export interface IKanBan {
issues: any;
sub_group_by: string | null;
group_by: string | null;
sub_group_id?: string;
handleIssues?: () => void;
handleDragDrop?: (result: any) => void | undefined;
}

export const KanBan: React.FC<IKanBan> = observer(({ issues, sub_group_by, group_by, sub_group_id = "null" }) => {
const { project: projectStore, issueKanBanView: issueKanBanViewStore }: RootStore = useMobxStore();

return (
<div className="relative w-full h-full">
{group_by && group_by === "state" && (
<GroupByKanBan
issues={issues}
group_by={group_by}
sub_group_by={sub_group_by}
sub_group_id={sub_group_id}
list={projectStore?.projectStates}
listKey={`id`}
isDragDisabled={!issueKanBanViewStore?.canUserDragDrop}
/>
)}

{group_by && group_by === "state_detail.group" && (
<div className="relative w-full h-full flex">
{ISSUE_STATE_GROUPS &&
ISSUE_STATE_GROUPS.length > 0 &&
ISSUE_STATE_GROUPS.map((stateGroup) => (
<div className="flex-shrink-0 flex flex-col w-[300px] h-full">
{sub_group_by === null && (
<div className="flex-shrink-0 w-full">
<KanBanGroupByHeaderRoot column_id={stateGroup?.key} />
</div>
)}
<div className="w-full h-full">content</div>
</div>
))}
</div>
<GroupByKanBan
issues={issues}
group_by={group_by}
sub_group_by={sub_group_by}
sub_group_id={sub_group_id}
list={ISSUE_STATE_GROUPS}
listKey={`key`}
isDragDisabled={!issueKanBanViewStore?.canUserDragDrop}
/>
)}

{group_by && group_by === "priority" && (
<div className="relative w-full h-full flex">
{ISSUE_PRIORITIES &&
ISSUE_PRIORITIES.length > 0 &&
ISSUE_PRIORITIES.map((priority) => (
<div className="flex-shrink-0 flex flex-col w-[300px] h-full">
{sub_group_by === null && (
<div className="flex-shrink-0 w-full">
<KanBanGroupByHeaderRoot column_id={priority?.key} />
</div>
)}
<div className="w-full h-full">content</div>
</div>
))}
</div>
<GroupByKanBan
issues={issues}
group_by={group_by}
sub_group_by={sub_group_by}
sub_group_id={sub_group_id}
list={ISSUE_PRIORITIES}
listKey={`key`}
isDragDisabled={!issueKanBanViewStore?.canUserDragDrop}
/>
)}

{group_by && group_by === "labels" && (
<div className="relative w-full h-full flex">
{projectStore?.projectLabels &&
projectStore?.projectLabels.length > 0 &&
projectStore?.projectLabels.map((label) => (
<div className="flex-shrink-0 flex flex-col w-[300px] h-full">
{sub_group_by === null && (
<div className="flex-shrink-0 w-full">
<KanBanGroupByHeaderRoot column_id={label?.id} />
</div>
)}
<div className="w-full h-full">content</div>
</div>
))}
</div>
<GroupByKanBan
issues={issues}
group_by={group_by}
sub_group_by={sub_group_by}
sub_group_id={sub_group_id}
list={projectStore?.projectLabels}
listKey={`id`}
isDragDisabled={!issueKanBanViewStore?.canUserDragDrop}
/>
)}

{group_by && group_by === "assignees" && (
<div className="relative w-full h-full flex">
{projectStore?.projectMembers &&
projectStore?.projectMembers.length > 0 &&
projectStore?.projectMembers.map((member) => (
<div className="flex-shrink-0 flex flex-col w-[300px] h-full">
{sub_group_by === null && (
<div className="flex-shrink-0 w-full">
<KanBanGroupByHeaderRoot column_id={member?.id} />
</div>
)}
<div className="w-full h-full">content</div>
</div>
))}
</div>
<GroupByKanBan
issues={issues}
group_by={group_by}
sub_group_by={sub_group_by}
sub_group_id={sub_group_id}
list={projectStore?.projectMembers}
listKey={`member.id`}
isDragDisabled={!issueKanBanViewStore?.canUserDragDrop}
/>
)}

{group_by && group_by === "created_by" && (
<div className="relative w-full h-full flex">
{projectStore?.projectMembers &&
projectStore?.projectMembers.length > 0 &&
projectStore?.projectMembers.map((member) => (
<div className="flex-shrink-0 flex flex-col w-[300px] h-full">
{sub_group_by === null && (
<div className="flex-shrink-0 w-full">
<KanBanGroupByHeaderRoot column_id={member?.id} />
</div>
)}
<div className="w-full h-full">content</div>
</div>
))}
</div>
<GroupByKanBan
issues={issues}
group_by={group_by}
sub_group_by={sub_group_by}
sub_group_id={sub_group_id}
list={projectStore?.projectMembers}
listKey={`member.id`}
isDragDisabled={!issueKanBanViewStore?.canUserDragDrop}
/>
)}
</div>
);
Loading