Sha256: 0fac964013fb8af6deae361253d803046d45ed3a72cc1f3bcaafd213df9779f6

Contents?: true

Size: 1.8 KB

Versions: 4

Compression:

Stored size: 1.8 KB

Contents

import * as Drag from "../../types/Drag";

function hovering<T>(
  dragState: Drag.State<T>,
  target: Drag.Item<T> | React.MutableRefObject<HTMLDivElement>
) {
  const { x, y } = dragState;
  let rect: DOMRect;
  if (typeof target === "string") {
    return false;
  }
  if ("rect" in target) {
    rect = target.rect;
  } else if ("current" in target && target.current) {
    rect = target.current.getBoundingClientRect();
  } else {
    return false;
  }
  return x >= rect.left && x <= rect.right && y >= rect.top && y <= rect.bottom;
}

export function collectionOrder<T>(
  collection: Drag.Collection<T>,
  dragState: Drag.State<T>
): Array<Drag.Item<T>> {
  const { draggables, ref } = collection;
  const { dragging } = dragState;

  if (!dragging) {
    return draggables;
  }

  let ordered: Drag.Item<T>[] = draggables;
  if (typeof dragging !== "string") {
    ordered = draggables
      .filter((d) => typeof d !== "string")
      .filter((d: Drag.Draggable<T>) => d.handle !== dragging.handle);
  }
  if (hovering(dragState, ref)) {
    const hovered = ordered.filter((d) => hovering(dragState, d))[0];
    if (hovered) {
      const index = ordered.indexOf(hovered);
      ordered = [...ordered.slice(0, index), dragging, ...ordered.slice(index)];
    } else {
      ordered = [...ordered, dragging];
    }
  }

  return ordered;
}

export default function draggedOrder<T>(
  collection: Drag.Collection<T>,
  dragState: Drag.State<T>
) {
  let ordered = collectionOrder(collection, dragState);

  if (dragState.dragging && ordered.indexOf(dragState.dragging) === -1) {
    if (
      collection.ref.current &&
      dragState.y < collection.ref.current.getBoundingClientRect().top
    ) {
      ordered = [dragState.dragging, ...ordered];
    } else {
      ordered.push(dragState.dragging);
    }
  }

  return ordered;
}

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
pages_core-3.15.4 app/javascript/components/drag/draggedOrder.ts
pages_core-3.15.3 app/javascript/components/drag/draggedOrder.ts
pages_core-3.15.2 app/javascript/components/drag/draggedOrder.ts
pages_core-3.15.1 app/javascript/components/drag/draggedOrder.ts