mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
fix: resolved rendering issues in list and kanban layout when we apply group-by filter (#4028)
This commit is contained in:
parent
991b8e7703
commit
86ae79f851
@ -25,7 +25,7 @@ import {
|
|||||||
} from "@/hooks/store";
|
} from "@/hooks/store";
|
||||||
// types
|
// types
|
||||||
// parent components
|
// parent components
|
||||||
import { getGroupByColumns } from "../utils";
|
import { getGroupByColumns, isWorkspaceLevel } from "../utils";
|
||||||
// components
|
// components
|
||||||
import { KanbanStoreType } from "./base-kanban-root";
|
import { KanbanStoreType } from "./base-kanban-root";
|
||||||
import { HeaderGroupByCard } from "./headers/group-by-card";
|
import { HeaderGroupByCard } from "./headers/group-by-card";
|
||||||
@ -102,7 +102,9 @@ const GroupByKanBan: React.FC<IGroupByKanBan> = observer((props) => {
|
|||||||
moduleInfo,
|
moduleInfo,
|
||||||
label,
|
label,
|
||||||
projectState,
|
projectState,
|
||||||
member
|
member,
|
||||||
|
true,
|
||||||
|
isWorkspaceLevel(storeType)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!list) return null;
|
if (!list) return null;
|
||||||
|
@ -13,7 +13,7 @@ import {
|
|||||||
} from "@plane/types";
|
} from "@plane/types";
|
||||||
// components
|
// components
|
||||||
import { useCycle, useLabel, useMember, useModule, useProject, useProjectState } from "@/hooks/store";
|
import { useCycle, useLabel, useMember, useModule, useProject, useProjectState } from "@/hooks/store";
|
||||||
import { getGroupByColumns } from "../utils";
|
import { getGroupByColumns, isWorkspaceLevel } from "../utils";
|
||||||
import { KanbanStoreType } from "./base-kanban-root";
|
import { KanbanStoreType } from "./base-kanban-root";
|
||||||
import { KanBan } from "./default";
|
import { KanBan } from "./default";
|
||||||
import { HeaderGroupByCard } from "./headers/group-by-card";
|
import { HeaderGroupByCard } from "./headers/group-by-card";
|
||||||
@ -291,7 +291,9 @@ export const KanBanSwimLanes: React.FC<IKanBanSwimLanes> = observer((props) => {
|
|||||||
projectModule,
|
projectModule,
|
||||||
label,
|
label,
|
||||||
projectState,
|
projectState,
|
||||||
member
|
member,
|
||||||
|
true,
|
||||||
|
isWorkspaceLevel(storeType)
|
||||||
);
|
);
|
||||||
const subGroupByList = getGroupByColumns(
|
const subGroupByList = getGroupByColumns(
|
||||||
sub_group_by as GroupByColumnTypes,
|
sub_group_by as GroupByColumnTypes,
|
||||||
@ -300,7 +302,9 @@ export const KanBanSwimLanes: React.FC<IKanBanSwimLanes> = observer((props) => {
|
|||||||
projectModule,
|
projectModule,
|
||||||
label,
|
label,
|
||||||
projectState,
|
projectState,
|
||||||
member
|
member,
|
||||||
|
true,
|
||||||
|
isWorkspaceLevel(storeType)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!groupByList || !subGroupByList) return null;
|
if (!groupByList || !subGroupByList) return null;
|
||||||
|
@ -13,9 +13,8 @@ import { IssueBlocksList, ListQuickAddIssueForm } from "@/components/issues";
|
|||||||
// hooks
|
// hooks
|
||||||
import { EIssuesStoreType } from "@/constants/issue";
|
import { EIssuesStoreType } from "@/constants/issue";
|
||||||
import { useCycle, useLabel, useMember, useModule, useProject, useProjectState } from "@/hooks/store";
|
import { useCycle, useLabel, useMember, useModule, useProject, useProjectState } from "@/hooks/store";
|
||||||
// constants
|
// utils
|
||||||
// types
|
import { getGroupByColumns, isWorkspaceLevel } from "../utils";
|
||||||
import { getGroupByColumns } from "../utils";
|
|
||||||
import { HeaderGroupByCard } from "./headers/group-by-card";
|
import { HeaderGroupByCard } from "./headers/group-by-card";
|
||||||
|
|
||||||
export interface IGroupByList {
|
export interface IGroupByList {
|
||||||
@ -78,7 +77,7 @@ const GroupByList: React.FC<IGroupByList> = (props) => {
|
|||||||
projectState,
|
projectState,
|
||||||
member,
|
member,
|
||||||
true,
|
true,
|
||||||
true
|
isWorkspaceLevel(storeType)
|
||||||
);
|
);
|
||||||
|
|
||||||
if (!groups) return null;
|
if (!groups) return null;
|
||||||
|
@ -70,8 +70,8 @@ export const HeaderGroupByCard = observer(
|
|||||||
{icon ? icon : <CircleDashed className="h-3.5 w-3.5" strokeWidth={2} />}
|
{icon ? icon : <CircleDashed className="h-3.5 w-3.5" strokeWidth={2} />}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div className="flex w-full flex-row items-center gap-1">
|
<div className="relative flex w-full flex-row items-center gap-1 overflow-hidden">
|
||||||
<div className="line-clamp-1 font-medium text-custom-text-100">{title}</div>
|
<div className="inline-block line-clamp-1 truncate font-medium text-custom-text-100">{title}</div>
|
||||||
<div className="pl-2 text-sm font-medium text-custom-text-300">{count || 0}</div>
|
<div className="pl-2 text-sm font-medium text-custom-text-300">{count || 0}</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -4,7 +4,7 @@ import { Avatar, CycleGroupIcon, DiceIcon, PriorityIcon, StateGroupIcon } from "
|
|||||||
// components
|
// components
|
||||||
import { ProjectLogo } from "@/components/project";
|
import { ProjectLogo } from "@/components/project";
|
||||||
// stores
|
// stores
|
||||||
import { ISSUE_PRIORITIES } from "@/constants/issue";
|
import { ISSUE_PRIORITIES, EIssuesStoreType } from "@/constants/issue";
|
||||||
import { STATE_GROUPS } from "@/constants/state";
|
import { STATE_GROUPS } from "@/constants/state";
|
||||||
import { ICycleStore } from "@/store/cycle.store";
|
import { ICycleStore } from "@/store/cycle.store";
|
||||||
import { ILabelStore } from "@/store/label.store";
|
import { ILabelStore } from "@/store/label.store";
|
||||||
@ -16,6 +16,9 @@ import { IStateStore } from "@/store/state.store";
|
|||||||
// constants
|
// constants
|
||||||
// types
|
// types
|
||||||
|
|
||||||
|
export const isWorkspaceLevel = (type: EIssuesStoreType) =>
|
||||||
|
[EIssuesStoreType.PROFILE, EIssuesStoreType.GLOBAL].includes(type) ? true : false;
|
||||||
|
|
||||||
export const getGroupByColumns = (
|
export const getGroupByColumns = (
|
||||||
groupBy: GroupByColumnTypes | null,
|
groupBy: GroupByColumnTypes | null,
|
||||||
project: IProjectStore,
|
project: IProjectStore,
|
||||||
|
@ -96,7 +96,9 @@ export const GlobalViewsHeader: React.FC = observer(() => {
|
|||||||
</Link>
|
</Link>
|
||||||
))}
|
))}
|
||||||
|
|
||||||
{currentWorkspaceViews?.map((viewId) => <ViewTab key={viewId} viewId={viewId} />)}
|
{currentWorkspaceViews?.map((viewId) => (
|
||||||
|
<ViewTab key={viewId} viewId={viewId} />
|
||||||
|
))}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{isAuthorizedUser && (
|
{isAuthorizedUser && (
|
||||||
|
@ -29,8 +29,8 @@ const GlobalViewIssuesPage: NextPageWithLayout = observer(() => {
|
|||||||
currentWorkspace?.name && defaultView?.label
|
currentWorkspace?.name && defaultView?.label
|
||||||
? `${currentWorkspace?.name} - ${defaultView?.label}`
|
? `${currentWorkspace?.name} - ${defaultView?.label}`
|
||||||
: currentWorkspace?.name && globalViewDetails?.name
|
: currentWorkspace?.name && globalViewDetails?.name
|
||||||
? `${currentWorkspace?.name} - ${globalViewDetails?.name}`
|
? `${currentWorkspace?.name} - ${globalViewDetails?.name}`
|
||||||
: undefined;
|
: undefined;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
|
Loading…
Reference in New Issue
Block a user