diff --git a/web/components/cycles/gantt-chart/blocks.tsx b/web/components/cycles/gantt-chart/blocks.tsx index 68e25a43c..b63becb02 100644 --- a/web/components/cycles/gantt-chart/blocks.tsx +++ b/web/components/cycles/gantt-chart/blocks.tsx @@ -76,6 +76,7 @@ export const CycleGanttSidebarBlock: React.FC = observer((props) => { = observer((props) => { cycleStatus === "current" ? "#09a953" : cycleStatus === "upcoming" - ? "#f7ae59" - : cycleStatus === "completed" - ? "#3f76ff" - : cycleStatus === "draft" - ? "rgb(var(--color-text-200))" - : "" + ? "#f7ae59" + : cycleStatus === "completed" + ? "#3f76ff" + : cycleStatus === "draft" + ? "rgb(var(--color-text-200))" + : "" }`} />
{cycleDetails?.name}
diff --git a/web/components/gantt-chart/sidebar/cycles/block.tsx b/web/components/gantt-chart/sidebar/cycles/block.tsx index 7922e86a6..8247dcacf 100644 --- a/web/components/gantt-chart/sidebar/cycles/block.tsx +++ b/web/components/gantt-chart/sidebar/cycles/block.tsx @@ -15,13 +15,11 @@ import { findTotalDaysInRange } from "@/helpers/date-time.helper"; type Props = { block: IGanttBlock; - enableReorder: boolean; isDragging: boolean; - dragHandleRef: MutableRefObject; }; export const CyclesSidebarBlock: React.FC = observer((props) => { - const { block, enableReorder, isDragging, dragHandleRef } = props; + const { block, isDragging } = props; // store hooks const { updateActiveBlockId, isBlockActive } = useGanttChart(); @@ -44,16 +42,6 @@ export const CyclesSidebarBlock: React.FC = observer((props) => { height: `${BLOCK_HEIGHT}px`, }} > - {enableReorder && ( - - )}
diff --git a/web/components/gantt-chart/sidebar/cycles/sidebar.tsx b/web/components/gantt-chart/sidebar/cycles/sidebar.tsx index e0bee915b..540560491 100644 --- a/web/components/gantt-chart/sidebar/cycles/sidebar.tsx +++ b/web/components/gantt-chart/sidebar/cycles/sidebar.tsx @@ -37,14 +37,7 @@ export const CycleGanttSidebar: React.FC = (props) => { isDragEnabled={enableReorder} onDrop={handleOnDrop} > - {(isDragging: boolean, dragHandleRef: MutableRefObject) => ( - - )} + {(isDragging: boolean) => } )) ) : ( diff --git a/web/components/gantt-chart/sidebar/gantt-dnd-HOC.tsx b/web/components/gantt-chart/sidebar/gantt-dnd-HOC.tsx index a337a9fa8..ae02a983c 100644 --- a/web/components/gantt-chart/sidebar/gantt-dnd-HOC.tsx +++ b/web/components/gantt-chart/sidebar/gantt-dnd-HOC.tsx @@ -3,7 +3,7 @@ import { combine } from "@atlaskit/pragmatic-drag-and-drop/combine"; import { draggable, dropTargetForElements } from "@atlaskit/pragmatic-drag-and-drop/element/adapter"; import { attachInstruction, extractInstruction } from "@atlaskit/pragmatic-drag-and-drop-hitbox/tree-item"; import { observer } from "mobx-react"; -import { DropIndicator } from "@plane/ui"; +import { DropIndicator, TOAST_TYPE, setToast } from "@plane/ui"; import { HIGHLIGHT_WITH_LINE, highlightIssueOnDrop } from "@/components/issues/issue-layouts/utils"; import useOutsideClickDetector from "@/hooks/use-outside-click-detector"; @@ -11,7 +11,7 @@ type Props = { id: string; isLastChild: boolean; isDragEnabled: boolean; - children: (isDragging: boolean, dragHandleRef: MutableRefObject) => JSX.Element; + children: (isDragging: boolean) => JSX.Element; onDrop: (draggingBlockId: string | undefined, droppedBlockId: string | undefined, dropAtEndOfList: boolean) => void; }; @@ -22,11 +22,9 @@ export const GanttDnDHOC = observer((props: Props) => { const [instruction, setInstruction] = useState<"DRAG_OVER" | "DRAG_BELOW" | undefined>(undefined); // refs const blockRef = useRef(null); - const dragHandleRef = useRef(null); useEffect(() => { const element = blockRef.current; - const dragHandleElement = dragHandleRef.current; if (!element) return; @@ -34,7 +32,6 @@ export const GanttDnDHOC = observer((props: Props) => { draggable({ element, canDrag: () => isDragEnabled, - dragHandle: dragHandleElement ?? undefined, getInitialData: () => ({ id }), onDragStart: () => { setIsDragging(true); @@ -90,14 +87,27 @@ export const GanttDnDHOC = observer((props: Props) => { }, }) ); - }, [blockRef?.current, dragHandleRef?.current, isLastChild, onDrop]); + }, [blockRef?.current, isLastChild, onDrop]); useOutsideClickDetector(blockRef, () => blockRef?.current?.classList?.remove(HIGHLIGHT_WITH_LINE)); return ( -
+
{ + if (!isDragEnabled) { + setToast({ + title: "Warning!", + type: TOAST_TYPE.WARNING, + message: "Drag and drop is only enabled when sorted by manual", + }); + } + }} + > - {children(isDragging, dragHandleRef)} + {children(isDragging)} {isLastChild && }
); diff --git a/web/components/gantt-chart/sidebar/issues/block.tsx b/web/components/gantt-chart/sidebar/issues/block.tsx index df0fd64fb..e04605949 100644 --- a/web/components/gantt-chart/sidebar/issues/block.tsx +++ b/web/components/gantt-chart/sidebar/issues/block.tsx @@ -18,15 +18,13 @@ import { IGanttBlock } from "../../types"; type Props = { block: IGanttBlock; - enableReorder: boolean; enableSelection: boolean; isDragging: boolean; - dragHandleRef: MutableRefObject; selectionHelpers?: TSelectionHelper; }; export const IssuesSidebarBlock = observer((props: Props) => { - const { block, enableReorder, enableSelection, isDragging, dragHandleRef, selectionHelpers } = props; + const { block, enableSelection, isDragging, selectionHelpers } = props; // store hooks const { updateActiveBlockId, isBlockActive } = useGanttChart(); const { getIsIssuePeeked } = useIssueDetail(); @@ -58,16 +56,6 @@ export const IssuesSidebarBlock = observer((props: Props) => { }} >
- {enableReorder && ( - - )} {enableSelection && selectionHelpers && ( = (props) => { isDragEnabled={enableReorder} onDrop={handleOnDrop} > - {(isDragging: boolean, dragHandleRef: MutableRefObject) => ( + {(isDragging: boolean) => ( )} diff --git a/web/components/gantt-chart/sidebar/modules/block.tsx b/web/components/gantt-chart/sidebar/modules/block.tsx index e6b28d54a..7ee9e53a4 100644 --- a/web/components/gantt-chart/sidebar/modules/block.tsx +++ b/web/components/gantt-chart/sidebar/modules/block.tsx @@ -15,13 +15,11 @@ import { findTotalDaysInRange } from "@/helpers/date-time.helper"; type Props = { block: IGanttBlock; - enableReorder: boolean; isDragging: boolean; - dragHandleRef: MutableRefObject; }; export const ModulesSidebarBlock: React.FC = observer((props) => { - const { block, enableReorder, isDragging, dragHandleRef } = props; + const { block, isDragging } = props; // store hooks const { updateActiveBlockId, isBlockActive } = useGanttChart(); @@ -44,16 +42,6 @@ export const ModulesSidebarBlock: React.FC = observer((props) => { height: `${BLOCK_HEIGHT}px`, }} > - {enableReorder && ( - - )}
diff --git a/web/components/gantt-chart/sidebar/modules/sidebar.tsx b/web/components/gantt-chart/sidebar/modules/sidebar.tsx index e162d2517..e2a3a5bd4 100644 --- a/web/components/gantt-chart/sidebar/modules/sidebar.tsx +++ b/web/components/gantt-chart/sidebar/modules/sidebar.tsx @@ -37,14 +37,7 @@ export const ModuleGanttSidebar: React.FC = (props) => { isDragEnabled={enableReorder} onDrop={handleOnDrop} > - {(isDragging: boolean, dragHandleRef: MutableRefObject) => ( - - )} + {(isDragging: boolean) => } )) ) : ( diff --git a/web/components/modules/gantt-chart/blocks.tsx b/web/components/modules/gantt-chart/blocks.tsx index 191b42210..bed4c91dd 100644 --- a/web/components/modules/gantt-chart/blocks.tsx +++ b/web/components/modules/gantt-chart/blocks.tsx @@ -67,6 +67,7 @@ export const ModuleGanttSidebarBlock: React.FC = observer((props) => {
{moduleDetails?.name}