import { Avatar, PriorityIcon, StateGroupIcon } from "@plane/ui"; import { ISSUE_PRIORITIES } from "constants/issue"; import { renderEmoji } from "helpers/emoji.helper"; import { IMemberRootStore } from "store/member"; import { IProjectStore } from "store/project/project.store"; import { IStateStore } from "store/state.store"; import { GroupByColumnTypes, IGroupByColumn } from "@plane/types"; import { STATE_GROUPS } from "constants/state"; import { ILabelStore } from "store/label.store"; export const getGroupByColumns = ( groupBy: GroupByColumnTypes | null, project: IProjectStore, label: ILabelStore, projectState: IStateStore, member: IMemberRootStore, includeNone?: boolean ): IGroupByColumn[] | undefined => { switch (groupBy) { case "project": return getProjectColumns(project); case "state": return getStateColumns(projectState); case "state_detail.group": return getStateGroupColumns(); case "priority": return getPriorityColumns(); case "labels": return getLabelsColumns(label) as any; case "assignees": return getAssigneeColumns(member) as any; case "created_by": return getCreatedByColumns(member) as any; default: if (includeNone) return [{ id: `null`, name: `All Issues`, payload: {}, icon: undefined }]; } }; const getProjectColumns = (project: IProjectStore): IGroupByColumn[] | undefined => { const { workspaceProjectIds: projectIds, projectMap } = project; if (!projectIds) return; return projectIds .filter((projectId) => !!projectMap[projectId]) .map((projectId) => { const project = projectMap[projectId]; return { id: project.id, name: project.name, icon:
{renderEmoji(project.emoji || "")}
, payload: { project_id: project.id }, }; }) as any; }; const getStateColumns = (projectState: IStateStore): IGroupByColumn[] | undefined => { const { projectStates } = projectState; if (!projectStates) return; return projectStates.map((state) => ({ id: state.id, name: state.name, icon: (
), payload: { state_id: state.id }, })) as any; }; const getStateGroupColumns = () => { const stateGroups = STATE_GROUPS; return Object.values(stateGroups).map((stateGroup) => ({ id: stateGroup.key, name: stateGroup.label, icon: (
), payload: {}, })); }; const getPriorityColumns = () => { const priorities = ISSUE_PRIORITIES; return priorities.map((priority) => ({ id: priority.key, name: priority.title, icon: , payload: { priority: priority.key }, })); }; const getLabelsColumns = (label: ILabelStore) => { const { projectLabels } = label; if (!projectLabels) return; const labels = [...projectLabels, { id: "None", name: "None", color: "#666" }]; return labels.map((label) => ({ id: label.id, name: label.name, icon: (
), payload: label?.id === "None" ? {} : { label_ids: [label.id] }, })); }; const getAssigneeColumns = (member: IMemberRootStore) => { const { project: { projectMemberIds }, getUserDetails, } = member; if (!projectMemberIds) return; const assigneeColumns: any = projectMemberIds.map((memberId) => { const member = getUserDetails(memberId); return { id: memberId, name: member?.display_name || "", icon: , payload: { assignee_ids: [memberId] }, }; }); assigneeColumns.push({ id: "None", name: "None", icon: , payload: {} }); return assigneeColumns; }; const getCreatedByColumns = (member: IMemberRootStore) => { const { project: { projectMemberIds }, getUserDetails, } = member; if (!projectMemberIds) return; return projectMemberIds.map((memberId) => { const member = getUserDetails(memberId); return { id: memberId, name: member?.display_name || "", icon: , payload: {}, }; }); };