Skip to content

Commit

Permalink
some tweaks
Browse files Browse the repository at this point in the history
  • Loading branch information
jerader committed Feb 13, 2024
1 parent 2018908 commit 30ad3c1
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 29 deletions.
51 changes: 23 additions & 28 deletions protocol-designer/src/components/steplist/DraggableStepItems.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -25,18 +25,16 @@ interface DragDropStepItemProps extends ConnectedStepItemProps {
stepNumber: number
findStepIndex: (stepIdType: StepIdType) => number
onDrag: () => void
moveStep: (stepId: StepIdType, value: number) => void
moveStep: (draggedId: StepIdType, value: number) => void
}

const DragDropStepItem = (props: DragDropStepItemProps): JSX.Element => {
const { onDrag, stepId, findStepIndex, moveStep } = props
console.log('stepId', stepId)
const ref = React.useRef(null)

const [{ isDragging }, drag] = useDrag(() => ({
type: DND_TYPES.STEP_ITEM,
beginDrag: () => {
onDrag()
return { stepId: stepId }
},
item: { stepId },
collect: (monitor: DragLayerMonitor) => ({
isDragging: monitor.isDragging(),
}),
Expand All @@ -47,22 +45,24 @@ const DragDropStepItem = (props: DragDropStepItemProps): JSX.Element => {
canDrop: () => {
return false
},
hover: (item: any) => {
console.log('item', item)
const draggedId = item.stepId
hover: (item: { stepId: StepIdType }) => {
const draggedId: StepIdType = item.stepId
const targetIndex = findStepIndex(stepId)
const draggedIndex = findStepIndex(draggedId)

const adjustedTargetIndex =
draggedIndex < targetIndex ? targetIndex - 1 : targetIndex

if (draggedId !== stepId) {
const overIndex = findStepIndex(stepId)
moveStep(draggedId, overIndex)
moveStep(draggedId, adjustedTargetIndex)
}
},
}))

drag(drop(ref))
return (
<div ref={drop} style={{ opacity: isDragging ? 0.3 : 1 }}>
<div ref={drag}>
<ConnectedStepItem {...props} stepId={stepId} />
</div>
<div ref={ref} style={{ opacity: isDragging ? 0.3 : 1 }}>
<ConnectedStepItem {...props} stepId={stepId} />
</div>
)
}
Expand All @@ -79,21 +79,17 @@ export const DraggableStepItems = (props: StepItemsProps): JSX.Element => {
setStepIds(orderedStepIds)
}

const submitReordering = (): void => {
if (
confirm(
'Are you sure you want to reorder these steps, it may cause errors?'
)
) {
reorderSteps(stepIds)
}
}

const [{ isOver }, drop] = useDrop(() => ({
accept: DND_TYPES.STEP_ITEM,
drop: () => {
if (!isEqual(orderedStepIds, stepIds)) {
submitReordering()
if (
confirm(
'Are you sure you want to reorder these steps, it may cause errors?'
)
) {
reorderSteps(stepIds)
}
}
},
collect: (monitor: DropTargetMonitor) => ({
Expand All @@ -120,8 +116,7 @@ export const DraggableStepItems = (props: StepItemsProps): JSX.Element => {
stepIds.findIndex(id => stepId === id)

const currentIds = isOver ? stepIds : orderedStepIds
console.log('stepIds', stepIds)
console.log('currentStepIds', currentIds)

return (
<div ref={drop}>
<ContextMenu>
Expand Down
2 changes: 1 addition & 1 deletion protocol-designer/src/containers/ConnectedStepItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ export const ConnectedStepItem = (
props: ConnectedStepItemProps
): JSX.Element => {
const { stepId, stepNumber } = props

const step = useSelector(stepFormSelectors.getSavedStepForms)[stepId]
const argsAndErrors = useSelector(stepFormSelectors.getArgsAndErrorsByStepId)[
stepId
Expand Down

0 comments on commit 30ad3c1

Please sign in to comment.