// mobx import { observer } from "mobx-react-lite"; // lucide icons import { Layers, Link, Paperclip } from "lucide-react"; // components import { IssuePropertyState } from "../properties/state"; import { IssuePropertyPriority } from "../properties/priority"; import { IssuePropertyLabels } from "../properties/labels"; import { IssuePropertyAssignee } from "../properties/assignee"; import { IssuePropertyEstimates } from "../properties/estimates"; import { IssuePropertyDate } from "../properties/date"; import { Tooltip } from "@plane/ui"; import { IEstimatePoint, IIssue, IIssueLabels, IState, IUserLite, TIssuePriorities } from "types"; export interface IKanBanProperties { sub_group_id: string; columnId: string; issue: IIssue; handleIssues: (sub_group_by: string | null, group_by: string | null, issue: IIssue) => void; display_properties: any; states: IState[] | null; labels: IIssueLabels[] | null; members: IUserLite[] | null; estimates: IEstimatePoint[] | null; } export const KanBanProperties: React.FC = observer((props) => { const { sub_group_id, columnId: group_id, issue, handleIssues, display_properties, states, labels, members, estimates, } = props; const handleState = (state: IState) => { handleIssues( !sub_group_id && sub_group_id === "null" ? null : sub_group_id, !group_id && group_id === "null" ? null : group_id, { ...issue, state: state.id } ); }; const handlePriority = (value: TIssuePriorities) => { handleIssues( !sub_group_id && sub_group_id === "null" ? null : sub_group_id, !group_id && group_id === "null" ? null : group_id, { ...issue, priority: value } ); }; const handleLabel = (ids: string[]) => { handleIssues( !sub_group_id && sub_group_id === "null" ? null : sub_group_id, !group_id && group_id === "null" ? null : group_id, { ...issue, labels_list: ids } ); }; const handleAssignee = (ids: string[]) => { handleIssues( !sub_group_id && sub_group_id === "null" ? null : sub_group_id, !group_id && group_id === "null" ? null : group_id, { ...issue, assignees_list: ids } ); }; const handleStartDate = (date: string) => { handleIssues( !sub_group_id && sub_group_id === "null" ? null : sub_group_id, !group_id && group_id === "null" ? null : group_id, { ...issue, start_date: date } ); }; const handleTargetDate = (date: string) => { handleIssues( !sub_group_id && sub_group_id === "null" ? null : sub_group_id, !group_id && group_id === "null" ? null : group_id, { ...issue, target_date: date } ); }; const handleEstimate = (value: number | null) => { handleIssues( !sub_group_id && sub_group_id === "null" ? null : sub_group_id, !group_id && group_id === "null" ? null : group_id, { ...issue, estimate_point: value } ); }; return (
{/* basic properties */} {/* state */} {display_properties && display_properties?.state && ( )} {/* priority */} {display_properties && display_properties?.priority && ( )} {/* label */} {display_properties && display_properties?.labels && ( )} {/* assignee */} {display_properties && display_properties?.assignee && ( )} {/* start date */} {display_properties && display_properties?.start_date && ( handleStartDate(date)} disabled={false} placeHolder="Start date" /> )} {/* target/due date */} {display_properties && display_properties?.due_date && ( handleTargetDate(date)} disabled={false} placeHolder="Target date" /> )} {/* estimates */} {display_properties && display_properties?.estimate && ( )} {/* extra render properties */} {/* sub-issues */} {display_properties && display_properties?.sub_issue_count && (
{issue.sub_issues_count}
)} {/* attachments */} {display_properties && display_properties?.attachment_count && (
{issue.attachment_count}
)} {/* link */} {display_properties && display_properties?.link && (
{issue.link_count}
)}
); });