// 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 { IIssue, IState, TIssuePriorities } from "types"; import { ICycleIssuesFilterStore, IModuleIssuesFilterStore, IProfileIssuesFilterStore, IProjectIssuesFilterStore, IViewIssuesFilterStore, } from "store_legacy/issues"; import { WithDisplayPropertiesHOC } from "../properties/with-display-properties-HOC"; export interface IKanBanProperties { issue: IIssue; handleIssues: (issue: IIssue) => void; issuesFilter: | IProjectIssuesFilterStore | IModuleIssuesFilterStore | ICycleIssuesFilterStore | IViewIssuesFilterStore | IProfileIssuesFilterStore; showEmptyGroup: boolean; isReadOnly: boolean; } export const KanBanProperties: React.FC = observer((props) => { const { issue, handleIssues, issuesFilter, isReadOnly } = props; const handleState = (state: IState) => { handleIssues({ ...issue, state: state.id }); }; const handlePriority = (value: TIssuePriorities) => { handleIssues({ ...issue, priority: value }); }; const handleLabel = (ids: string[]) => { handleIssues({ ...issue, labels: ids }); }; const handleAssignee = (ids: string[]) => { handleIssues({ ...issue, assignees: ids }); }; const handleStartDate = (date: string) => { handleIssues({ ...issue, start_date: date }); }; const handleTargetDate = (date: string) => { handleIssues({ ...issue, target_date: date }); }; const handleEstimate = (value: number | null) => { handleIssues({ ...issue, estimate_point: value }); }; return (
{/* basic properties */} {/* state */} displayProperties && displayProperties?.state} > {/* priority */} displayProperties && displayProperties?.priority} > {/* label */} displayProperties && displayProperties?.labels} > {/* start date */} displayProperties?.start_date} > handleStartDate(date)} disabled={isReadOnly} type="start_date" /> {/* target/due date */} displayProperties?.due_date} > handleTargetDate(date)} disabled={isReadOnly} type="target_date" /> {/* assignee */} displayProperties?.assignee} > {/* estimates */} displayProperties?.estimate} > {/* extra render properties */} {/* sub-issues */} displayProperties?.sub_issue_count && !!issue?.sub_issues_count} >
{issue.sub_issues_count}
{/* attachments */} displayProperties?.attachment_count && !!issue?.attachment_count } >
{issue.attachment_count}
{/* link */} displayProperties?.link && !!issue?.link_count} >
{issue.link_count}
); });